Angular 6 - Routing

Zasadniczo routing oznacza nawigację między stronami. Widziałeś wiele witryn z linkami kierującymi do nowej strony. Można to osiągnąć za pomocą routingu. Tutaj strony, do których się odnosimy, będą miały postać komponentów. Widzieliśmy już, jak stworzyć komponent. Utwórzmy teraz komponent i zobaczmy, jak używać z nim routingu.

W głównym komponencie macierzystym app.module.ts, musimy teraz dołączyć moduł routera, jak pokazano poniżej -

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { RouterModule} from '@angular/router';
import { AppComponent } from './app.component';
import { NewCmpComponent } from './new-cmp/new-cmp.component';
import { ChangeTextDirective } from './change-text.directive';
import { SqrtPipe } from './app.sqrt';
@NgModule({
   declarations: [
      SqrtPipe,
      AppComponent,
      NewCmpComponent,
      ChangeTextDirective
   ],
   imports: [
      BrowserModule,
      RouterModule.forRoot([
         {
            path: 'new-cmp',
            component: NewCmpComponent
         }
      ])
   ],
   providers: [],
   bootstrap: [AppComponent]
})
export class AppModule { }

importuj {RouterModule} z „@ angular / router”

Tutaj RouterModule jest importowany z angular / router. Moduł jest uwzględniony w imporcie, jak pokazano poniżej -

RouterModule.forRoot([
   {
      path: 'new-cmp',
      component: NewCmpComponent
   }
])

RouterModule odnosi się do forRootktóry przyjmuje dane wejściowe jako tablicę, która z kolei zawiera obiekt ścieżki i komponent. Ścieżka to nazwa routera, a komponent to nazwa klasy, czyli utworzonego komponentu.

Zobaczmy teraz utworzony plik komponentu -

New-cmp.component.ts

import { Component, OnInit } from '@angular/core';
@Component({
   selector: 'app-new-cmp',
   templateUrl: './new-cmp.component.html',
   styleUrls: ['./new-cmp.component.css']
})
export class NewCmpComponent implements OnInit {
   newcomponent = "Entered in new component created";
   constructor() {}
   ngOnInit() { }
}

Podświetlona klasa jest wymieniona w imporcie modułu głównego.

New-cmp.component.html

<p>
   {{newcomponent}}
</p>

<p>
   new-cmp works!
</p>

Teraz potrzebujemy, aby powyższa zawartość z pliku html była wyświetlana w razie potrzeby lub po kliknięciu z głównego modułu. W tym celu musimy dodać szczegóły routera wapp.component.html.

<h1>Custom Pipe</h1>
<b>Square root of 25 is: {{25 | sqrt}}</b><br/>
<b>Square root of 729 is: {{729 | sqrt}}</b>
<br />
<br />
<br />
<a routerLink = "new-cmp">New component</a>
<br />
<br/>
<router-outlet></router-outlet>

W powyższym kodzie utworzyliśmy tag anchor link i nadaliśmy routerLink jako "new-cmp". Jest to określone wapp.module.ts jako ścieżka.

Gdy użytkownik kliknie new component, strona powinna wyświetlać treść. W tym celu potrzebujemy następującego tagu -<router-outlet> </router-outlet>.

Powyższy tag zapewnia, że ​​zawartość w new-cmp.component.html wyświetli się na stronie po kliknięciu przez użytkownika new component.

Zobaczmy teraz, jak dane wyjściowe są wyświetlane w przeglądarce.

Gdy użytkownik kliknie Nowy komponent, w przeglądarce zobaczysz następujące informacje.

Adres URL zawiera http://localhost:4200/new-cmp. Tutaj nowy-cmp zostanie dołączony do oryginalnego adresu URL, który jest ścieżką podaną wapp.module.ts i łącze routera w app.component.html.

Gdy użytkownik kliknie Nowy komponent, strona nie jest odświeżana, a zawartość jest wyświetlana użytkownikowi bez ponownego ładowania. Po kliknięciu ponownie załadowany zostanie tylko określony fragment kodu witryny. Ta funkcja pomaga, gdy na stronie mamy dużo treści i musimy ją załadować na podstawie interakcji użytkownika. Ta funkcja zapewnia również dobre wrażenia użytkownika, ponieważ strona nie jest ponownie ładowana.