Angular4学习笔记router的简单使用
前端之家收集整理的这篇文章主要介绍了
Angular4学习笔记router的简单使用,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_301_0@router,也就是路由,是前端中一个比较重要的概念。通过router把特定的地址和对应的页面关联后分离出来,以达到解耦的目的。在src/app目录下新建一个detail的文件夹,建立一个名为gundam-detail.component的文件。
<div class="jb51code">
<pre class="brush:js;">
import { Component } from '@angular/core';
import { Gundam } from '../../model/gundam';
@Component({
template: `
<div *ngIf="selectedGundam">
{{selectedGundam.name}}
{{selectedGundam.type}}
`
})
export class GundamDetailComponent {
selectedGundam: Gundam;
}
@H_
301_0@ps:有关命名,基本上是采用xxx+“-”+“业务类型”+“组件类型”的命名方式,至少官方文档上是这么推荐的。当然给组件起名叫猪头三也可以,但是标准的命名可以
增加组件的可读性。即便是不介意随意起名坑后来的维护者,谁也不能确定很长时间以后自己不会再对同一段
代码进行重构。所以,做人还是要厚道。不写注释也就算了,起名还是规范一点好。
@H_
301_0@ps2:有关分包的方式,有的人喜欢把view放一起、controller放一起,再根据逻辑进一步细分;也有人是倒过来,先分逻辑再分view和controller。这个好像没有什么统一的定论,我个人是喜欢后一种,所以本项目采用后一种分法。
@H_
301_0@目前
文件里没什么东西,只是简单的把app.component.ts里的temple给搬过来而已。
@H_
301_0@先明确需求,再开始写router。
@H_
301_0@
需求:点击gundam列表页面中的任意item,可以跳转到该gundam的详情页。
@H_
301_0@作为angular的组件,希望在
页面中使用router,必须先在app.module.ts里声明。
@H_
301_0@ps:之前的业务和app.module.ts没什么关系,但这并不是说它不重要。app.module.ts相当于android的mainifist
文件,对整个项目进行统筹管理。
@H_
301_0@打开app.module.ts:
- imports:在组件页面里用到基础类。
- declarations:现有custom组件声明。
- bootstrap:可以理解为Android的main launch,项目启动时从那个组件进入。
@H_
301_0@需要使用router前先引入:
@H_
301_0@因为要
调用RouterModule的forRoot
方法,RouterModule.forRoot 又是项目中用到的基础类,所以需要写在imports里。
@H_
301_0@RouterModule.forRoot 接受两个参数,第一个是route数组来表明
跳转,第二个参数常年忽略,我也不知道有什么用。
@H_
301_0@route类
包括2个比较关键的
属性:path和component,通过访问path,可以找到唯一的component。
@H_
301_0@在forRoot里
添加上包含主页和详情页2个component的route数组。
@H_
301_0@app.module.ts现在看起来是这样的:
@H_
301_0@2个path都还空着,因为还少一个关键的东西,就算写上也会报错:
@H_
301_0@Error: Cannot find primary outlet to load ‘AppComponent'
@H_
301_0@在angular里,router是要搭配
标签router-outlet来使用的,换句话说router决定
显示哪个组件,而由router-outlet决定
显示在哪里。
@H_
301_0@在
app.component.ts里的template
加上标签
@H_
301_0@然后不出意外的
显示了2个主页:
@H_
301_0@
app.component.ts是一个组件也是一个
页面,angular先从bootstrap里进入了
app.component.ts渲染了界面(也就是router-outlet上面的部分)。碰到又去找router,发现对应的router也有组件,于是又加载了一遍。
@H_
301_0@所以为了正常
显示,也要把主页也单独抽出来。所有组件通过
app.component.ts里的来进行加载。而
app.component.ts作为整个demo的最外层容器可以进行一些公共的操作(典型:后退动作)。
@H_
301_0@在src下新建host包,新建gundam-host.component.ts
文件。
基本上可以把整个app挪过来,
删除掉out
标签,删掉selector(暂时用不到)。
{{gundam.name}}
`
})
export class GundamHostComponent {
gundam: Gundam = {
name: '海牛',type: 'NewType'
};
gundams = GUNDAMS;
selectedGundam: Gundam; // 定义一个selectedGudam作为展示详情的变量
onSelected (gundam: Gundam): void {
this.selectedGundam = gundam; // 通过参数赋值
}
}
@H_
301_0@app.component.ts只保留
标签,其他一概去掉。
@H_
301_0@
修改app.module.ts文件,导入
gundam-host.component.ts并把GundamHostComponent
增加到组件声明declarations里。
@H_
301_0@
修改route里的path所指向的component,默认进入后
显示主页组件:
@H_
301_0@before
@H_
301_0@after
@H_
301_0@path的值为”(空字符串)的表示不需要
增加子路径。
@H_
301_0@
修改详情页的路径:
@H_
301_0@在主页里
增加跳转连接:
@H_
301_0@点击
跳转(路径已改变)
@H_
301_0@现在点击主页的高达列表的item后,可以
跳转到一个空白的详情页。之所以是空白,是因为详情页的值是需要由主页进行传递的。现在主页详情页分家以后,需要通过路由来进行值传递。
@H_
301_0@传值的
方法有很多种,甚至可以传的值也有很多种。
目前我先用最笨的
方法:将gundam类转化为一个字符串,将字符串传递到详情
页面后再转化为gundam类。
@H_
301_0@在app.component.ts
文件的class里
添加函数:
@H_
301_0@
修改app.component.ts
文件的template,访问gundam路径时转化传递转化过的gundam字符串
{{gundam.name}}
@H_
301_0@
修改详情页的path
@H_
301_0@/:gundam 是一个占位符,又是参数说明。表示传递过来的参数
属性是gundam。
@H_
301_0@这样在detail
文件中,就可以从url的连接中拿到传递过来的高达字符串。
@H_
301_0@获得这个字符串的时机,应该是在在detail
页面初始化的时候。Angular提供了所谓的的“钩子”(hook),用来标示component的活动周期—其实也就是是类似于Android里onStart或者onCreate一样的
方法。
@H_
301_0@在
gundam-detail.component.ts的中
添加OnInit钩子,或者说接口:
@H_
301_0@在class后面加implements关键词和OnInit来实现该接口:
@H_
301_0@剩下的事情,就是读取连接
上传来的参数就可以了。
@H_
301_0@读取连接
上传递的参数还是要用到router里的几个类,所以需要在detail里导入。
@H_
301_0@导入完成后,通过在构造器里注入的方式进行
调用:
@H_
301_0@(有关注入,现在暂时没有说到)
@H_
301_0@angular会
自动创建ActivatedRoute的实例。
@H_
301_0@先在ngOnInit里
输出看看params是什么
console.log(params))
@H_
301_0@ps:switchMap是angular官方给的拿取url参数的
方法,也是需要预先导入才可以使用:
@H_
301_0@ps2: 有关箭头
函数
this.gundamStr = params['gundam']
@H_
301_0@是一个箭头
函数,等同于
@H_
301_0@其中params是switchMap的返回值,返回的即是通过路由连接传递过来的参数所在的类。
@H_
301_0@ps3: 箭头
函数真的是整个ES6里最恶心的东西,之一。
@H_
301_0@控制台中
输出:
@H_
301_0@传递过来的参数,是一个gundam类格式化
输出的字符串,所以还要在detail里补充一个反格式化字符串到gundam类的
函数。
@H_
301_0@最终,获得detail的初始化是这个样子的
this.gundamStr = params['gundam']) // 通过参数拿到gundam字符串并付给detail里的一个临时变量
.subscribe(() => this.selectedGundam = this.parseStringToGundam(this.gundamStr)); // 通过反格式化
函数解析临时变量并返回给作为
显示的model
}
@H_
301_0@移动web
页面间传值确实没有什么太好的
方法,angular和react都是如此。以前我们的做法是短的参数直接挂连接传走,长的大的或者object的参数就先保存本地,然后第二个
页面再从本地读取。
@H_
301_0@但是像android那样扔一个intent里直接就过去了的方式,确实没有。
@H_
301_0@
回首页:
@H_301_0@作为router,也可以分离的。
@H_
301_0@目前我的项目里只有2个
页面,如果多起来-比如20来个,那么app.module.ts又会变的乱七八糟。
@H_
301_0@所以要把router也给扔出去。
@H_
301_0@新建一个
文件app-routing.module.ts,然后把footRoot平移过来(带上引用)。
@H_
301_0@在app-routing.module.ts
文件里,也需要ngModul。个人理解ngModul就相当于一个基类指示器,导出class后以便被其他类引用。
@H_
301_0@然后既然已经有了这个类,可以导入到
app.module.ts里使用使得整个
文件看起来清爽一些。
调用路由
],GundamDetailComponent,GundamHostComponent
],})
export class AppModule {}
@H_
301_0@当然,官方文档又进行了进一步简化。
@H_
301_0@既然forRoot是一个Route数组,那么数组也可以单独抽出来,当然进一步抽取也可以放到另一个
文件里。
@H_
301_0@我个人比较偷懒,就先抽取到这一步。
@H_
301_0@现在连主
页面和详情
页面都被分开了,项目的耦合度又进一步降低。
@H_
301_0@再接再厉,我们继续把业务逻辑给也分离出来。
@H_301_0@以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。