angular 8 配置路由
一、生成路由文件
按照惯例,有一个独立模块来配置相关路由,这个模块类的名字叫做AppRoutingModule,位于src/app下的app-routing.module.ts文件中。
使用CLI生成它。
ng generate module app-routing --flat --module=app
然后查看src/app目录下是否生成成功。
接下来,我们查看生成的文件:

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common'; @NgModule({
imports: [
CommonModule
],
declarations: []
})
export class AppRoutingModule { }

通常不会在路由模块中声明组件,所以可以删除@NgModule.declarations
并删除对 CommonModule
的引用。
二、导出 RouterModule
此刻的AppRoutingModule是这样的:

import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router'; @NgModule({
exports: [ RouterModule ]
})
export class AppRoutingModule {}

三、添加路由定义
典型的Angular路由(Route)有两个属性:
1、path:一个用于匹配浏览器地址栏中URL的字符串。
2、component:当导航到此路由时,路由应该创建哪个组件。
如果说你希望当URL为http://localhost:4200/homePage时,首先要导入HomePageComponent;以便在Route中引用它。
如下:

import { NgModule } from '@angular/core';
import {RouterModule, Routes} from "@angular/router";
import {HomePageComponent} from "../home-page/home-page.component"; const routes: Routes = [
{ path: 'homePage', component: HomePageComponent }
];
@NgModule({
exports: [RouterModule]
})
export class AppRoutingModule { }

RouterModule.forRoot()
初始化路由器,并让它开始监听浏览器的地址变化。(添加到 @NgModule.imports
数组中)
imports: [ RouterModule.forRoot(routes) ],
注意:
查看app.module.ts文件中是否有引入AppRoutingModule。
import { AppRoutingModule } from './app-routing/app-routing.module';
imports: [
AppRoutingModule
],
四、添加路由出口
打开AppComponent的模板,把<router-outlet>添加进去,<router-outlet>会告诉路由器要在哪里显示路由的试图。
<router-outlet></router-outlet> // src/app/app.component.html
五、运行项目
查看项目页面,注意你的CLI命令行是否仍在运行:
ng serve
地址栏输入http://localhost:4200,这个时候你会看到地址栏显示着项目的标题,但是并没有显示HomePageComponent中的内容。
六、添加默认路由
方法一:当启动项目时,浏览器的地址栏指向的是网站的根路径。它没有匹配到任何现存路由,因此路由器也不会导航到任何地方。
要让应用自动导航到这个仪表盘,请把下列路由添加到AppRoutingModule.routes数组中。
{ path: '', redirectTo: '/homePage', pathMatch: 'full' },
现在再次访问项目,你会发现地址栏默认会把一个空路径重定向到'/homePage'的路由;并且首页也加载了HomePageComponent。
方法二:
{ path: '**', component:DashboardComponent}
意思就是当路由URL等于’’时,会去加载DashboardComponent组件;所以你运行你的服务端口号:localhost:4200首先加载的就会是这个组件;
**
路径是一个通配符,表示除了以上几种path,任何的路径都会加载DashboardComponent组件,这个记得写在路由配置最后。
七、添加路由链接(routerLink)
不应该让用户只能把路由的 URL 粘贴到地址栏中。他们还应该能通过点击链接进行导航。
添加一个 <nav>
元素,并在其中放一个链接 <a>元素,当点击它时,就会触发一个到 DetailsComponent 的导航。
<div>
home-page works!
<nav>
<a routerLink="/details">点击查看详情</a>
</nav>
</div>
同时需要把DetailsComponent引入到AppRoutingModule中。
点击查看详情这个链接。地址栏变成了/details,并且页面跳转到详情页。
八、添加详情视图(HTML传参)
现在假设我们首页展示的是一个文章列表,然后我们需要点击每一遍文章查看详情;如果说我们要导航到id为11的文章详情视图,类似于http://localhost:4200/heroes/11的URL。
首先打开AppRoutingModule并导入HeroesComponent。
import {HeroesComponent} from "./heroes/heroes.component";
然后把一个参数化路由添加到 AppRoutingModule.routes
数组中,它要匹配指向文章详情视图的路径。
{ path: 'heroes/:id', component: HeroesComponent }
path
中的冒号(:
)表示 :id
是一个占位符,它表示某个特定英雄的 id
。
此刻,路由就准备就绪了。
然后,我们需要修改HTML页面中的文章列表跳转链接,让它们能够通过参数化的路由进行导航到文章详情页面。
<nav>
<a routerLink="/heroes/{{id}}">点击查看文章详情</a>
<!--数组格式传参-->
<a [routerLink]="['/heroes', num]">点击查看文章详情</a>
</nav>
现在我们刷新页面点击查看文章详情,你发现,地址栏已经更改为http://localhost:4200/heroes/11,页面展示也已经跳转到文章详情页面模块。
九、js页面跳转(传参)
当你在AppRoutingModule导入了HeroesComponent,并且把一个参数化路由添加到 AppRoutingModule.routes
数组中。
我们现在需要通过js传参跳转到HeroesComponent(几个常用的方法):
1、先添加下列导入语句:
import { Router } from '@angular/router';//引入
然后把 ActivatedRoute
注入到构造函数中,将它们的值保存到私有变量里:
constructor( private router: Router) { }//注入到构造函数
2、传递路由参数
单参传递
navigate()该方法支持的参数类型和routerLink指令一样,所以它们的作用也是一样的:
this.router.navigate(['heroes', id]);
或者:
this.router.navigate(['heroes']);
多参传递
this.router.navigate(['heroDetail'], {queryParams: {productId: '1',title: 'moon'}
3、我们注意到还有一个:navigateByUrl(),这个叫做绝对路由;
this.router.navigateByUrl('home');
区别:navigateByUrl()和navigate()的区别点是:navigateByUrl不是根据参数来确定路由地址的。
十、从路由参数中提取id
1、先添加下列导入语句:
import { ActivatedRoute } from '@angular/router';
然后把 ActivatedRoute
注入到构造函数中,将它们的值保存到私有变量里:
constructor(
private route: ActivatedRoute,
) {}
ActivatedRoute
保存着到这个 HeroDetailComponent
实例的路由信息。 这个组件对从 URL 中提取的路由参数感兴趣。 其中的 id
参数就是要显示的英雄的 id
。
2、获取路由参数
方法一:
this.route.queryParams.subscribe(queryParams => {
let productId = queryParams.productId;
let title = queryParams.title;
});
方法二:
代码如下:

public params; //公有变量
ngOnInit() {
this.getData();
}
getData() {
this.route.params.subscribe(
params => {
this.params = params;
console.log(this.params);
}
);
}

这样获取的是一个对象,直接获取id就可以了。
方法三:
代码如下:

ngOnInit(): void {
this.getData();
} getData(): void {
const id = +this.route.snapshot.paramMap.get('id');
console.log(id);
}

十一、回到原路
1、先添加下列导入语句:
import { Location } from '@angular/common';
然后把 Location
服务注入到构造函数中,将它们的值保存到私有变量里:
constructor(
private location: Location
) {}
location
是一个 Angular 的服务,用来与浏览器打交道。 稍后,你就会使用它来导航回上一个视图。
2、点击返回页面:
通过点击浏览器的后退按钮,可以回到上一个也买你进入的页面。
把一个后退按钮添加到组件模板的底部,并且把它绑定到组件的 goBack() 方法。
<button (click)="goBack()">go back</button>
在组件类中添加一个 goBack()
方法,利用注入的Location
服务在浏览器的历史栈中后退一步。
goBack(): void {
this.location.back();
}
angular 8 配置路由的更多相关文章
- angular配置路由/子页面+vue配置路由/子页面
1.在vue.js中组件可以复用,然后最近配置了几个子页面 在 这个文件中配置路由,子页面的配置跟其他一样,只不过path不同. routes: [ { path: '/', ...
- Angular配置路由以及动态路由取值传值跳转
Angular配置路由 1.找到 app-routing.module.ts 配置路由 引入组件 import { HomeComponent } from './home/home.componen ...
- Angular routing生成路由和路由的跳转
Angular routing生成路由和路由的跳转 什么是路由 路由的目的是可以让根组件按照不同的需求动态加载不同的组件. 根据不同地址,加载不同组件,实现单页面应用. Angular 命令创建一个配 ...
- Angular学习笔记—路由(转载)
创建路由 1.首先安装 Angular Router.你可以通过运行以下任一操作来执行此操作: yarn add @angular/router # OR npm i --save @angular/ ...
- [SignalR]配置路由
原文:[SignalR]配置路由 注册路由,在代码如下(SignalR 1.*): 脚本修改如下: 但是其官方文档解释是: By default, the route URL which client ...
- angular.js的路由和模板在asp.net mvc 中的使用
angular.js的路由和模板在asp.net mvc 中的使用 我们知道angular.js是基于mvc 的一款优秀js框架,它也有一套自己的路由机制,和asp.net mvc 路由不太一样.as ...
- vue2.0配置路由
配置路由之前,先检查vue版本,(案例适用vue2.0) 采用npm包的形式进行安装. 安装路由依赖:npm install vue-router(代码中,如果在一个模块化工程中使用它,必须要通过 V ...
- flutter 入口文件配置路由+加载页面
入口文件配置路由 1.路由信息 -- 加载页面 ,通常用于显示新的内容或者广告,加载完成之后进入主页面 -- 主页面 /app 2.配置页面 main.dart main.dart // main ...
- Vue2+VueRouter2+webpack 构建项目实战(三):配置路由,运行页面
制作.vue模板文件 通过前面的两篇博文的学习,我们已经建立好了一个项目.问题是,我们还没有开始制作页面.下面,我们要来做页面了. 我们还是利用 http://cnodejs.org/api 这里公开 ...
随机推荐
- Linux在线安装Redis
一.进入Redis官网寻找需要下载的版本:https://redis.io/ 将下载地址链接复制下来:http://download.redis.io/releases/redis-5.0.7.tar ...
- 第06组 Alpha冲刺(1/4)
队名:福大帮 组长博客链接:https://www.cnblogs.com/mhq-mhq/p/11863075.html 作业博客 :https://edu.cnblogs.com/campus/f ...
- 城东C位之路!探秘三线楼市板块崛起3大核心基因
等着咧!伍家篇什么时候出?这就出. 城东C位之路!- 诸葛磊 好几个粉丝已经在催了,诸葛磊决定改变下写作策略,伍家岗篇分版块用小篇幅来写,这样文章不至于太长,否则又是一篇洋洋洒洒上万字的文章,粉丝看着 ...
- 微信小程序开发——微信小程序下拉刷新真机无法弹回
开发工具中下拉之后页面回弹有一定的延迟,这个时间也有点久.真机测试,下拉后连回弹都没有,这个问题要解决,就得在下拉函数里加上停止下拉刷新的API,如下: /** * 下拉刷新 */ onPullDow ...
- JSON序列化和反序列化 对decmail 取值问题
地图API返回经纬度:经度: 纬度: lng":114.03483089395202,"lat":22.615589046911805 decmail 接收数据后两位会截 ...
- 并行执行任务 Stat-Job
最近在写一些powershell脚本时候遇到一个问题,那就是要解压十几个zip文件,这样仅执行完解压操作差不多5min的时间就过去了,严重影响了效率,这时就想到了使用多线程的方法来执行这个解压操作,经 ...
- [计算机视觉][神经网络与深度学习]SSD安装及其训练教程
SSD的安装 在home目录下,获取SSD的代码,下载完成后有一个caffe文件夹 git clone https://github.com/weiliu89/caffe.git cd caffe g ...
- Burp Suite 如何抓取HTTPS请求
1,下载安装burp suite工具 https://portswigger.net/burp/communitydownload 如果是windows系统,选择windows点击Download下载 ...
- Linux08 文件系统
对于磁盘等各类存储设备中所有的数据都以0和1的概念,但对于用户来说,0和1是没有任何意义的,这时候就需要一种类似于“翻译”的机制存在于用户和磁盘之间,Linux中采用的是文件系统+虚拟文件系统(Vir ...
- web页面元素定位
所有web网页中有8种元素定位方式 靠单一的特征找元素:6种(id,class_name,tag_name,name,link_text(2))组合各种特征和关系来找元素:2种(xpath,css) ...