序言:

序言:

Angular APP 视图之间的跳转,重视于 Router (路由),那1章,大家来说述
Router 的选择

Angular 应用软件 视图之间的跳转,倚重于 Router (路由),那一章,大家来叙述
Router 的施用

实例讲明

运作结果如下。 设置了三个导航栏, Home、 About、Dashboard。
点击分歧的导航栏,跳转到相应的页面:

永利开户送38元体验金 1

image.png

实例批注

创建3个 component

ng g c home
ng g c about
ng g c dashboard

运作结果如下。 设置了一个导航栏, Home、 About、Dashboard。
点击差别的导航栏,跳转到相应的页面:

路由与陈设

(1)**引入 Angular Router **

当用到 Angular Router 时,必要引进 RouterModule,如下:

// app.module.ts
import { RouterModule } from '@angular/router';
imports: [
   BrowserModule, RouterModule
],

(2) 路由配置
还记得由何人来管理component 的啊,没错,由 module 来治本。
所以,把新创造的 component,引进到 app.moudle 中。 如下:

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { RouterModule } from '@angular/router';

import { appRoutes } from './routerConfig';

import { AppComponent } from './app.component';
import { AboutComponent } from './components/about/about.component';
import { HomeComponent } from './components/home/home.component';
import { DashboardComponent } from './components/dashboard/dashboard.component';

提醒: 注意component的门路,为便于管理,大家把新创设的component 移到了
components 文件夹中。

永利开户送38元体验金 2

创建 Router Configure 文件

在 app 目录下, 创造 routerConfig.ts 文件。 代码如下:

import { Routes } from '@angular/router';
import { HomeComponent } from './components/home/home.component';
import { AboutComponent } from './components/about/about.component';
import { DashboardComponent } from './components/dashboard/dashboard.component';

export const appRoutes: Routes = [
  { path: 'home', 
    component: HomeComponent 
  },
  {
    path: 'about',
    component: AboutComponent
  },
  { path: 'dashboard',
    component: DashboardComponent
  }
];

表达: Angular 二.X 以上版本,开首使用 TypeScript 编写代码,而不再是
JavaScript,所以,文件的后缀是: ts 而不是 js

其1 routerConfigue 文件,怎么调用呢? 要求把它加载到 app.module.ts
中,那是因为 app.moudle.ts 是全体Angular App 的入口。

// app.module.ts
import { appRoutes } from './routerConfig';
imports: [
    BrowserModule,
    RouterModule.forRoot(appRoutes)
],

创建3个 component

声明 Router Outlet

在 app.component.html 文件中,增添代码:

<div style="text-align:center">
    <h1>
     {{title}}!!
    </h1>
    <nav>
      <a routerLink="home" routerLinkActive="active">Home</a>
      <a routerLink="about">About</a>
      <a routerLink="dashboard">Dashboard</a>
    </nav>
    <router-outlet></router-outlet>
  </div>
  1. ng g c home
  2. ng g c about
  3. ng g c dashboard

运行

永利开户送38元体验金,进去到该工程所在的门路, 运营;

ng serve –open

当 webpack 编写翻译成功后,在浏览器地址栏中,输入:
http://localhost:4200
就可以看出本篇早先的结果。


关于Router,换一种写法:
在 app.moudle.ts 文件中,代码如下 :

 imports: [
     BrowserModule,
     RouterModule.forRoot(
       [
         { path: 'home', 
          component: HomeComponent 
         },
         {
          path: 'about',
          component: AboutComponent
         },
         {
          path: 'dashboard',
          component: DashboardComponent
         }
       ]
     )
   ],

那样壹来,能够不用单独创造 routerConfigure.ts 文件。

路由与布局

小结

自打引进了面向组件(component)后,路由管理比较 AngularJS
(一.X),方便了无数。

进而优化:

也许你早已注意到,当访问
http://localhost:4200
时,它的路线应该是 “/”, 咱们理应安装那几个默许的门径。

{
          path: '',
          redirectTo:'/home',
          pathMatch: 'full'
         },

(1)**引入 Angular Router **

当用到 Angular Router 时,须要引进 RouterModule,如下:

// app.module.ts
import { RouterModule } from '@angular/router';
imports: [
 BrowserModule, RouterModule
],

(2) 路由陈设

还记得由哪个人来管理component 的吧,没有错,由 module 来保管。
所以,把新创设的 component,引进到 app.moudle 中。 如下:

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { RouterModule } from '@angular/router';

import { appRoutes } from './routerConfig';

import { AppComponent } from './app.component';
import { AboutComponent } from './components/about/about.component';
import { HomeComponent } from './components/home/home.component';
import { DashboardComponent } from './components/dashboard/dashboard.component';

提醒: 注意component的路子,为便于管理,我们把新创造的component 移到了
components 文件夹中。

创建 Router Configure 文件

在 app 目录下, 创制 routerConfig.ts 文件。 代码如下:

import { Routes } from '@angular/router';
import { HomeComponent } from './components/home/home.component';
import { AboutComponent } from './components/about/about.component';
import { DashboardComponent } from './components/dashboard/dashboard.component';

export const appRoutes: Routes = [
 { path: 'home', 
 component: HomeComponent 
 },
 {
 path: 'about',
 component: AboutComponent
 },
 { path: 'dashboard',
 component: DashboardComponent
 }
];

申明: Angular 二.X 以上版本,开端运用 TypeScript 编写代码,而不再是
JavaScript,所以,文件的后缀是: ts 而不是 js

其一 routerConfigue 文件,怎么调用呢? 须要把它加载到 app.module.ts
中,那是因为 app.moudle.ts 是任何Angular App 的入口。

// app.module.ts
import { appRoutes } from './routerConfig';
imports: [
 BrowserModule,
 RouterModule.forRoot(appRoutes)
],

声明 Router Outlet

在 app.component.html 文件中,增加代码:

<div style="text-align:center">
 <h1>
  {{title}}!!
 </h1>
 <nav>
  <a routerLink="home" routerLinkActive="active">Home</a>
  <a routerLink="about">About</a>
  <a routerLink="dashboard">Dashboard</a>
 </nav>
 <router-outlet></router-outlet>
 </div>

运行

进去到该工程所在的路径, 运营;

ng serve --open

当 webpack 编写翻译成功后,在浏览器地址栏中,输入:

就可以看出本篇起初的结果。

关于Router,换一种写法:

在 app.moudle.ts 文件中,代码如下 :

 imports: [
  BrowserModule,
  RouterModule.forRoot(
  [
   { path: 'home', 
   component: HomeComponent 
   },
   {
   path: 'about',
   component: AboutComponent
   },
   {
   path: 'dashboard',
   component: DashboardComponent
   }
  ]
  )
 ],

那样壹来,能够不用单独创设 routerConfigure.ts 文件。

小结

自从引进了面向组件(component)后,路由处理比较 AngularJS
(一.X),方便了许多。

一发优化:

想必你早就注意到,当访问 时,它的路子应该是 “/”,
大家应有设置那一个暗中同意的不2秘籍。

{
   path: '',
   redirectTo:'/home',
   pathMatch: 'full'
   },

如上正是本文的全体内容,希望对我们的就学抱有援救,也可望大家多多帮忙脚本之家。

您大概感兴趣的篇章:

  • Angularjs中UI Router全攻略
  • angularJS中router的使用指南
  • angular第22中学router路由跳转navigate的施用与刷新页面难点详解
  • 详解Angular4中路由Router类的跳转navigate
  • Angular贰学习笔记——详解路由器模型(Router)
  • 浅析angularJS中的ui-router和ng-grid模块
  • Angularjs中UI
    Router的选择方法
  • angular基于路由调节ui-router实现系统权限调控
  • AngularJS ui-router
    (嵌套路由)实例
  • 详解Angular路由
    ng-route和ui-router的区别
  • Angular中利用ui
    router完结系统权限决定及开销遭遇难题

相关文章