Angular4.x路由的示例分析-创新互联

这篇文章给大家分享的是有关Angular 4.x路由的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

创新互联建站专注于锦江网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供锦江营销型网站建设,锦江网站制作、锦江网页设计、锦江网站官网定制、微信小程序开发服务,打造锦江网络公司原创品牌,更为您提供锦江网站排名全网营销落地服务。

Installing the router

首先第一件事,我们需要安装 Angular Router。你可以通过运行以下任一操作来执行此操作:

yarn add @angular/router
# OR
npm i --save @angular/router

以上命令执行后,将会自动下载@angular/router模块到node_modules文件夹中。

Base href

我们需要做的最后一件事,是将标签添加到我们的index.html文件中。路由需要根据这个来确定应用程序的根目录。例如,当我们转到http://example.com/page1时,如果我们没有定义应用程序的基础路径,路由将无法知道我们的应用的托管地址是http://example.com还是http://example.com/page1

这件事操作起来很简单,只需打开项目中的 index.html 文件,添加相应的 标签,具体如下:



 
 
 Application
 
 
 
 

以上配置信息告诉 Angular 路由,应用程序的根目录是/

Using the router

要使用路由,我们需要在AppModule模块中,导入RouterModule。具体如下:

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

import { AppComponent } from './app.component';

@NgModule({
 imports: [
 BrowserModule,
 RouterModule
 ],
 bootstrap: [
 AppComponent
 ],
 declarations: [
 AppComponent
 ]
})
export class AppModule {}

此时我们的路由还不能正常工作,因为我们还未配置应用程序路由的相关信息。RouterModule对象为我们提供了两个静态的方法:forRoot()forChild()来配置路由信息。

RouterModule.forRoot()

RouterModule.forRoot() 方法用于在主模块中定义主要的路由信息,通过调用该方法使得我们的主模块可以访问路由模块中定义的所有指令。接下来我们来看一下如何使用forRoot()

// ...
import { Routes, RouterModule } from '@angular/router';

export const ROUTES: Routes = [];

@NgModule({
 imports: [
 BrowserModule,
 RouterModule.forRoot(ROUTES)
 ],
 // ...
})
export class AppModule {}

我们通过使用const定义路由的配置信息,然后把它作为参数调用RouterModule.forRoot()方法,而不是直接使用RouterModule.forRoot([...])这种方式,这样做的好处是方便我们在需要的时候导出ROUTES到其它模块中。

RouterModule.forChild()

RouterModule.forChild() 与 Router.forRoot() 方法类似,但它只能应用在特性模块中。

友情提示:根模块中使用 forRoot(),子模块中使用 forChild()

这个功能非常强大,因为我们不必在一个地方(我们的主模块)定义所有路由信息。反之,我们可以在特性模块中定义模块特有的路由信息,并在必要的时候将它们导入我们主模块。RouterModule.forChild()的使用方法如下:

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { Routes, RouterModule } from '@angular/router';

export const ROUTES: Routes = [];

@NgModule({
 imports: [
 CommonModule,
 RouterModule.forChild(ROUTES)
 ],
 // ...
})
export class ChildModule {}

通过以上示例,我们知道在主模块和特性模块中,路由配置对象的类型是一样的,区别只是主模块和特性模块中需调用不同的方法,来配置模块路由。接下来我们来介绍一下如何配置ROUTES对象。

Configuring a route

我们定义的所有路由都是作为ROUTES数组中的对象。首先,为我们的主页定义一个路由:

import { Routes, RouterModule } from '@angular/router';

import { HomeComponent } from './home/home.component';

export const ROUTES: Routes = [
 { path: '', component: HomeComponent }
];

@NgModule({
 imports: [
 BrowserModule,
 RouterModule.forRoot(ROUTES)
 ],
 // ...
})
export class AppModule {}

示例中我们通过path属性定义路由的匹配路径,而component属性用于定义路由匹配时需要加载的组件。

友情提示:我们使用path: ''来匹配空的路径,例如:https://yourdomain.com

Displaying routes

配置完路由信息后,下一步是使用一个名为router-outlet的指令告诉 Angular 在哪里加载组件。当 Angular 路由匹配到响应路径,并成功找到需要加载的组件时,它将动态创建对应的组件,并将其作为兄弟元素,插入到router-outlet元素中。

在我们AppComponent组件中,我们可以在任意位置插入router-outlet指令:

import { Component } from '@angular/core';

@Component({
 selector: 'app-root',
 template: `
 
  

Our app

    
 ` }) export class AppComponent {}

我们现在已经建立了应用程序的主路由,我们可以进一步了解路由的其它配置选项。

Further configuration

到目前为止我们已经介绍的内容只是一个开始 ,接下来我们来看看其它一些选项和功能。

Dynamic routes

如果路由始终是静态的,那没有多大的用处。例如path: ''是加载我们HomeComponent组件的静态路由。我们将介绍动态路由,基于动态路由我们可以根据不同的路由参数,渲染不同的页面。

例如,如果我们想要在个人资料页面根据不同的用户名显示不同的用户信息,我们可以使用以下方式定义路由:

import { HomeComponent } from './home/home.component';
import { ProfileComponent } from './profile/profile.component';

export const ROUTES: Routes = [
 { path: '', component: HomeComponent },
 { path: '/profile/:username', component: ProfileComponent }
];

这里的关键点是:,它告诉 Angular 路由,:username是路由参数,而不是 URL 中实际的部分。

友情提示:如果没有使用 : ,它将作为静态路由,仅匹配 /profile/username 路径

现在我们已经建立一个动态路由,此时最重要的事情就是如何获取路由参数。要访问当前路由的相关信息,我们需要先从@angular/router模块中导入ActivatedRoute,然后在组件类的构造函数中注入该对象,最后通过订阅该对象的params属性,来获取路由参数,具体示例如下:

import { Component, OnInit } from '@angular/core';
import { ActivatedRoute } from '@angular/router';

@Component({
 selector: 'profile-page',
 template: `
 
  

{{ username }}

 
 ` }) export class SettingsComponent implements OnInit {  username: string;  constructor(private route: ActivatedRoute) {}  ngOnInit() {  this.route.params.subscribe((params) => this.username = params.username);  } }

介绍完动态路由,我们来探讨一下如何创建child routes

Child routes

实际上每个路由都支持子路由,假设在我们/settings设置页面下有/settings/profile/settings/password两个页面,分别表示个人资料页和修改密码页。

我们可能希望我们的/ settings页面拥有自己的组件,然后在设置页面组件中显示/ settings/profile/ settings/password页面。我们可以这样做:

import { SettingsComponent } from './settings/settings.component';
import { ProfileSettingsComponent } from './settings/profile/profile.component';
import { PasswordSettingsComponent } from './settings/password/password.component';

export const ROUTES: Routes = [
 { 
  path: 'settings', 
  component: SettingsComponent,
  children: [
   { path: 'profile', component: ProfileSettingsComponent },
   { path: 'password', component: PasswordSettingsComponent }
  ]
 }
];

@NgModule({
 imports: [
  BrowserModule,
  RouterModule.forRoot(ROUTES)
 ],
})
export class AppModule {}

在这里,我们在setttings路由中定义了两个子路由,它们将继承父路由的路径,因此修改密码页面的路由匹配地址是/settings/password,依此类推。

接下来,我们需要做的最后一件事是在我们的SettingsComponent组件中添加router-outlet指令,因为我们要在设置页面中呈现子路由。如果我们没有在SettingsComponent组件中添加router-outlet指令,尽管/settings/password匹配修改密码页面的路由地址,但修改密码页面将无法正常显示。具体代码如下:

import { Component } from '@angular/core';

@Component({
 selector: 'settings-page',
 template: `
  
   
   
   
  
 ` }) export class SettingsComponent {}

Component-less routes

另一个很有用的路由功能是component-less路由。使用component-less路由允许我们将路由组合在一起,并让它们共享路由配置信息和 outlet。

例如,我们可以定义setttings路由而不需要使用SettingsComponent组件:

import { ProfileSettingsComponent } from './settings/profile/profile.component';
import { PasswordSettingsComponent } from './settings/password/password.component';

export const ROUTES: Routes = [
 {
  path: 'settings',
  children: [
   { path: 'profile', component: ProfileSettingsComponent },
   { path: 'password', component: PasswordSettingsComponent }
  ]
 }
];

@NgModule({
 imports: [
  BrowserModule,
  RouterModule.forRoot(ROUTES)
 ],
})
export class AppModule {}

此时,/settings/profile/settings/password路由定义的内容,将显示在AppComponent组件的router-outlet元素中。

loadChildren

我们也可以告诉路由从另一个模块中获取子路由。这将我们谈论的两个想法联系在一起 - 我们可以指定另一个模块中定义的子路由,以及通过将这些子路由设置到特定的路径下,来充分利用component-less路由的功能。

让我们创建一个SettingsModule模块,用来保存所有setttings相关的路由信息:

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { Routes, RouterModule } from '@angular/router';

export const ROUTES: Routes = [
 {
  path: '',
  component: SettingsComponent,
  children: [
   { path: 'profile', component: ProfileSettingsComponent },
   { path: 'password', component: PasswordSettingsComponent }
  ]
 }
];

@NgModule({
 imports: [
  CommonModule,
  RouterModule.forChild(ROUTES)
 ],
})
export class SettingsModule {}

需要注意的是,在SettingsModule模块中我们使用forChild()方法,因为SettingsModule不是我们应用的主模块。

另一个主要的区别是我们将SettingsModule模块的主路径设置为空路径 ('')。因为如果我们路径设置为/settings,它将匹配/settings/settings,很明显这不是我们想要的结果。通过指定一个空的路径,它就会匹配/settings路径,这就是我们想要的结果。

那么/settings路由信息,需要在哪里配置?答案是在AppModule中。这时我们就需要用到loadChildren属性,具体如下:

export const ROUTES: Routes = [
 {
  path: 'settings',
  loadChildren: './settings/settings.module#SettingsModule'
 }
];

@NgModule({
 imports: [
  BrowserModule,
  RouterModule.forRoot(ROUTES)
 ],
 // ...
})
export class AppModule {}

需要注意的是,我们没有将SettingsModule导入到我们的AppModule中,而是通过loadChildren属性,告诉 Angular 路由依据loadChildren属性配置的路径去加载SettingsModule模块。这就是模块懒加载功能的具体应用,当用户访问/settings/**路径的时候,才会加载对应的SettingsModule模块,这减少了应用启动时加载资源的大小。

另外我们传递一个字符串作为loadChildren的属性值,该字符串由三部分组成:

  1. 需要导入模块的相对路径

  2. # 分隔符

  3. 导出模块类的名称

了解完路由的一些高级选项和功能,接下来我们来介绍路由指令。

Router Directives

除了router-outlet指令,路由模块中还提供了一些其它指令。让我们来看看它们如何与我们之前介绍的内容结合使用。

routerLink

为了让我们链接到已设置的路由,我们需要使用routerLink指令,具体示例如下:

当我们点击以上的任意链接时,页面不会被重新加载。反之,我们的路径将在 URL 地址栏中显示,随后进行后续视图更新,以匹配routerLink中设置的值。

友情提示:我们也可以将 routerLink 的属性值,改成数组形式,以便我们传递特定的路由信息

如果我们想要链接到动态的路由地址,且该地址有一个username的路由变量,则我们可以按照以下方式配置routerLink对应的属性值:


 Go to {{ username }}'s profile.

routerLinkActive

在实际开发中,我们需要让用户知道哪个路由处于激活状态,通常情况下我们通过向激活的链接添加一个 class 来实现该功能。为了解决上述问题,Angular 路由模块为我们提供了routerLinkActive指令,该指令的使用示例如下:

通过使用routerLinkActive指令,当a元素对应的路由处于激活状态时,active类将会自动添加到a元素上。

最后,我们来简单介绍一下 Router API。

Router API

我们可以通过路由还提供的 API 实现与routerLink相同的功能。要使用 Router API,我们需要在组件类中注入Router对象,具体如下:

import { Component } from '@angular/core';
import { Router } from '@angular/router';

@Component({
 selector: 'app-root',
 template: `
  
   

Our app

      
 ` }) export class AppComponent {  constructor(private router: Router) {} }

组件类中注入的router对象中有一个navigate()方法,该方法支持的参数类型与routerLink指令一样,当调用该方法后,页面将会自动跳转到对应的路由地址。具体使用示例如下:

import { Component, OnInit } from '@angular/core';
import { Router } from '@angular/router';

@Component({
 selector: 'app-root',
 template: `
  
   

Our app

        ` }) export class AppComponent implements OnInit {  constructor(private router: Router) {}  ngOnInit() {   setTimeout(() => {    this.router.navigate(['/settings']);   }, 5000);  } }

若以上代码成功运行,用户界面将在 5 秒后被重定向到/settings页面。这个方法非常有用,例如当检测到用户尚未登录时,自动重定向到登录页面。

另一个使用示例是演示页面跳转时如何传递数据,具体如下:

import { Component, OnInit } from '@angular/core';
import { Router } from '@angular/router';

@Component({
 selector: 'app-root',
 template: `
  
   

Users

                          ` }) export class AppComponent implements OnInit {  users: Username[] = [   { name: 'toddmotto', id: 0 },   { name: 'travisbarker', id: 1 },   { name: 'tomdelonge', id: 2 }  ];    constructor(private router: Router) {}    handleSelect(event) {   this.router.navigate(['/profile', event.name]);  } }

Angular 路由的功能非常强大,既可以使用指令方式也可以使用命令式 API,希望本文可以帮助你尽快入门,若要进一步了解路由详细信息,请访问 - Angular Router 官文文档。

我有话说

除了使用navigate()方法外还有没有其它方法可以实现页面导航?

Angular Router API 为我们提供了navigate()navigateByUrl()方法来实现页面导航。那为什么会有两个不同的方法呢?

使用router.navigateByUrl()方法与直接改变地址栏上的 URL 地址一样,我们使用了一个新的 URL 地址。然而router.navigate()方法基于一系列输入参数,产生一个新的 URL 地址。为了更好的区分它们之间的差异,我们来看个例子,假设当前的 URL 地址是:

/inbox/11/message/22(popup:compose)

当我们调用router.navigateByUrl('/inbox/33/message/44')方法后,此时的 URL 地址将变成/inbox/33/message/44。但如果我们是调用router.navigate('/inbox/33/message/44')方法,当前的 URL 地址将变成/inbox/33/message/44(popup:compose)

感谢各位的阅读!关于“Angular 4.x路由的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享标题:Angular4.x路由的示例分析-创新互联
标题链接:http://ybzwz.com/article/dsoojp.html

其他资讯