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.