Angular 2 - Маршрутизация
Маршрутизация помогает направлять пользователей на разные страницы в зависимости от варианта, который они выбирают на главной странице. Следовательно, в зависимости от выбранного ими варианта пользователю будет отображаться необходимый угловой компонент.
Давайте рассмотрим необходимые шаги, чтобы увидеть, как мы можем реализовать маршрутизацию в приложении Angular 2.
Step 1 - Добавьте тег базовой ссылки в файл index.html.
<!DOCTYPE html>
<html>
<head>
<base href = "/">
<title>Angular QuickStart</title>
<meta charset = "UTF-8">
<meta name = "viewport" content = "width = device-width, initial-scale = 1">
<base href = "/">
<link rel = "stylesheet" href = "styles.css">
<!-- Polyfill(s) for older browsers -->
<script src = "node_modules/core-js/client/shim.min.js"></script>
<script src = "node_modules/zone.js/dist/zone.js"></script>
<script src = "node_modules/systemjs/dist/system.src.js"></script>
<script src = "systemjs.config.js"></script>
<script>
System.import('main.js').catch(function(err){ console.error(err); });
</script>
</head>
<body>
<my-app></my-app>
</body>
</html>
Step 2- Создайте два маршрута для приложения. Для этого создайте 2 файла с именемInventory.component.ts а также product.component.ts
Step 3 - Поместите следующий код в файл product.component.ts.
import { Component } from '@angular/core';
@Component ({
selector: 'my-app',
template: 'Products',
})
export class Appproduct {
}
Step 4 - Поместите следующий код в файл Inventory.component.ts.
import { Component } from '@angular/core';
@Component ({
selector: 'my-app',
template: 'Inventory',
})
export class AppInventory {
}
Оба компонента не делают ничего необычного, они просто отображают ключевые слова на основе компонента. Таким образом, для компонента Inventory он будет отображать ключевое слово Inventory для пользователя. А для компонента продуктов пользователю будет показано ключевое слово продукта.
Step 5 - В файл app.module.ts добавьте следующий код -
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { Appproduct } from './product.component';
import { AppInventory } from './Inventory.component';
import { RouterModule, Routes } from '@angular/router';
const appRoutes: Routes = [
{ path: 'Product', component: Appproduct },
{ path: 'Inventory', component: AppInventory },
];
@NgModule ({
imports: [ BrowserModule,
RouterModule.forRoot(appRoutes)],
declarations: [ AppComponent,Appproduct,AppInventory],
bootstrap: [ AppComponent ]
})
export class AppModule { }
В отношении вышеуказанной программы необходимо отметить следующие моменты:
AppRoutes содержат 2 маршрута: один - это компонент Appproduct, а другой - компонент AppInventory.
Обязательно объявите оба компонента.
RouterModule.forRoot обеспечивает добавление маршрутов в приложение.
Step 6 - В файл app.component.ts добавьте следующий код.
import { Component } from '@angular/core';
@Component ({
selector: 'my-app',
template: `
<ul>
<li><a [routerLink] = "['/Product']">Product</a></li>
<li><a [routerLink] = "['/Inventory']">Inventory</a></li>
</ul>
<router-outlet></router-outlet>`
})
export class AppComponent { }
В отношении вышеупомянутой программы необходимо отметить следующее:
<router-outlet> </router-outlet> - это заполнитель для визуализации компонента на основе того, какой вариант выбирает пользователь.
Теперь сохраните весь код и запустите приложение с помощью npm. Зайдите в браузер, вы увидите следующий результат.
Теперь, если вы щелкните ссылку «Инвентарь», вы получите следующий результат.
Добавление маршрута ошибки
В маршрутизации также можно добавить маршрут ошибки. Это может произойти, если пользователь перейдет на страницу, которой нет в приложении.
Давайте посмотрим, как мы можем это реализовать.
Step 1 - Добавьте компонент PageNotFound как NotFound.component.ts, как показано ниже -
Step 2 - Добавьте в новый файл следующий код.
import { Component } from '@angular/core';
@Component ({
selector: 'my-app',
template: 'Not Found',
})
export class PageNotFoundComponent {
}
Step 3 - Добавьте следующий код в файл app.module.ts.
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { Appproduct } from './product.component'
import { AppInventory } from './Inventory.component'
import { PageNotFoundComponent } from './NotFound.component'
import { RouterModule, Routes } from '@angular/router';
const appRoutes: Routes = [
{ path: 'Product', component: Appproduct },
{ path: 'Inventory', component: AppInventory },
{ path: '**', component: PageNotFoundComponent }
];
@NgModule ({
imports: [ BrowserModule,
RouterModule.forRoot(appRoutes)],
declarations: [ AppComponent,Appproduct,AppInventory,PageNotFoundComponent],
bootstrap: [ AppComponent ]
})
export class AppModule {
}
В отношении вышеупомянутой программы необходимо отметить следующее:
Теперь у нас есть дополнительный маршрут с именем path: '**', component: PageNotFoundComponent. Следовательно, ** соответствует любому маршруту, который не соответствует маршруту по умолчанию. Они будут направлены в компонент PageNotFoundComponent.
Теперь сохраните весь код и запустите приложение с помощью npm. Зайдите в свой браузер, и вы увидите следующий результат. Теперь, когда вы перейдете по неверной ссылке, вы получите следующий результат.