Child Routing

Child Routing

მისამართის ცვლილება არ ხდება მხოლოდ ზედა დონეზე. არის შემთხვევები, როცა გვინდა კონკრეტული მისამართის შიგნით ნავიგაცია. აქ, წინასწარ გამზადებულ აპლიკაციაში გვაქვს ორი კომპონენტი: FirstComponent LastComponent და ისინი სათანადო მისამართებზე იტვირთება, როგორც ეს როუთინგის კონფიგურაციაშია:

app.routes.ts-ში:

TS
import { Routes } from "@angular/router";
import { FirstComponent } from "./first/first.component";
import { SecondComponent } from "./second/second.component";

export const routes: Routes = [
  { path: "first", component: FirstComponent },
  { path: "second", component: SecondComponent },
  { path: "", redirectTo: "first", pathMatch: "full" },
];

router-outlet გვაქვს განთავსებული AppComponent-ში. აქვე გვაქვს ჰედერი, საიდანაც ვაკეთებთ ნავიგაციას:

HTML
<header>
  <nav>
    <ul>
      <li><a routerLink="/first" routerLinkActive="active">First</a></li>
      <li><a routerLink="/second" routerLinkActive="active"> Second</a></li>
    </ul>
  </nav>
</header>
<router-outlet></router-outlet>

შენიშვნა: არ დაგავიწყდეთ კომპონენტში RouterModule-ის შემოტანა.

ახლა ვთქვათ გვინდა, რომ Second კომპონენტის შიგნით შევძლოთ კიდევ სხვადასხვა კომპონენტზე ნავიგაცია. შევქმნათ ორი კომპონენტი SecondComponent-ის შიგნით.

SH
ng g c second/child-one
SH
ng g c second/child-two

ამ კომპონენტებს უკვე აქვთ თემფლეითში მარკაპი, რომ შედეგი დავინახოთ. ახლა კონფიგურაციას მივხედოთ app.routes.ts-ში:

TS
import { Routes } from "@angular/router";
import { FirstComponent } from "./first/first.component";
import { ChildOneComponent } from "./second/child-one/child-one.component";
import { ChildTwoComponent } from "./second/child-two/child-two.component";
import { SecondComponent } from "./second/second.component";

export const routes: Routes = [
  { path: "first", component: FirstComponent },
  {
    path: "second",
    component: SecondComponent,
    children: [
      { path: "child-one", component: ChildOneComponent },
      { path: "child-two", component: ChildTwoComponent },
    ],
  },
  { path: "", redirectTo: "first", pathMatch: "full" },
];

იმ როუთისთვის, რომლის შიგნითაც გვინდა დამატებითო როუთების შექმნა, ვწერთ თვისება childern-ს სადაც გვექნება იგივე როუთის ობიექტების მასივი. აქ უკვე ჩვენ ახალ შექმნილ კომპონენტებს მივუთითებთ. დააკვირდით, რომ აქ პირდაპირ second როუთის შემდეგ რა მისამართი უნდა მოვიდეს იმას ვწერთმ და არა პირდაპირ second/child-one-ს, თუმცა ბრაუზერის მისამართში ეს სწორედ ასე იქნება.

ახლა SecondComponent-ში შევქმნათ ნავიგაციის ლინკები და, რა თქმა უნდა, router-outlet.

HTML
<p>second works!</p>
<nav>
  <ul>
    <li><a routerLink="child-one">Child One</a></li>
    <li><a routerLink="child-two">Child Two</a></li>
  </ul>
</nav>
<router-outlet></router-outlet>

დააკვირდით, რომ ახლა ვიყენებთ ფარდობით მისამართებს, ისინი არ იწყებიან /-ით. ეს ნიშნავს, რომ მიმდინარე მისამართის შიგნით მოხდება ნავიგაცია routerLink-ში ნაწილზე. ანუ შედეგად გვექნება second/child-one და second/child-two. თუ მას წინ დახრილ ხაზს დავუწერდით, ეს იქნებოდა გლობალური მისამართი, ანუ localhost:4200/child-one, რომელიც ჩვენ პროექტში არ არსებობს.

ახლა second მისამართის შიგნით child routing უნდა მუშაობდეს.

რამდენიმე რაუთის ერთდროულად ზარმაცად ჩატვირთვა

ჩვენ შეგვიძლია მთლიანი რაუთების კონფიგურაცია ჩავტვირთოთ ზარმაცად. წარმოვიდგინოთ რომ პროექტში გვაქვს ფოლდერი admin სადაც ინახება ადმინისტრატორის გვერდის კომპონენტები. ესენია: admin-home.component.ts, სადაც ადმინისტრატორის მთავარი გვერდია (/admin/home) და admin-users.component.ts, სადაც ადმინისტრატორი მომხმარებლებს მართავს (/admin/users). ამავე ფოლდერში შეიძლება გვქონდეს რაუთების კონფიგურაცია:

TS
// admin/admin.routes.ts

export const ADMIN_ROUTES: Route[] = [
  { path: "home", component: AdminHomeComponent },
  { path: "users", component: AdminUsersComponent },
  // ...
];

მაშინ შეგვიძლია მთავარი რაუთების კონფიგურაციის ობიექტში (app.routes.ts-ში) ის შემოვიტანოთ loadChildren თვისების ქვეშ:

TS
// app.routes.ts
export const routes: Route[] = [
  {
    path: "admin",
    loadChildren: () =>
      import("./admin/routes").then((mod) => mod.ADMIN_ROUTES),
  },
  // ...
];