0%

Angular——前端知识点总结

一、Angular 概述

基于命令行的开发方式?

1
2
3
4
①hot reload
②编译工作
③集成了webpack打包工具
。。。。

1、what?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
angular是一个Google推出的js框架,是以模块为基本单位,模块又可以包含组件、指令、过滤器。。

1.1 版本问题
angular angular2.0以后所有的版本统称为angular
(当前学习ng4.0)

angular.js angular1.* 统称为angular.js
(http://www.runoob.com/angularjs/angularjs-tutorial.html)

1.2 版本之间的区别
①新版本是有组件的概念的
②老版本是$scope和controller为主
③angular引入了rxjs
④angular采用ts(typescript是es6的超集,是由微软和谷歌) ts是一种强类型检查机制的语言
⑤angular可读性、提高了代码的复用率、维护成本变低。。。

2、where

1
2
3
可以使用支持angular的Ionic框架来实现移动端的开发,直接使用angular来实现pc端的开发

实现操作比较频繁的SPA

3、why

1
2
3
4
①遵循w3c所推出的webComponent标准(组件化)
②代码具有更好的可读性和可维护性、
③引入了更多的高效率的工具 ,比如rxjs\immutable.js。。。, 让代码的编译、部署更简单
④ts --》 健壮

4、how

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
angular的开发整体框架,是有8大组成部分构成

搭建环境的方式:
方式1:
①下载quickstart-master.zip压缩包
https://github.com/angular/quickstart download
或者 直接拷贝老师提供的压缩包
②解压缩 压缩包,进入对应的目录中
执行npm install 安装项目所需要用到的依赖
③npm start 启动开发服务器

方式2:
Angular CLI是一个命令行界面工具,它可以创建项目、
添加文件以及执行一大堆开发任务,比如测试、打包和发布。
//安装基于angular的命令工具
npm install -g @angular/cli
//创建一个有着ng模板的项目
ng new my-app
//进入当前目录下的my-app
cd my-app
//启动开发服务器
ng serve --open

二、Angular 模板项目的启动流程

1
2
3
4
5
6
7
index.html

main.js (main.ts)-->启动一个模块 AppModule

app/app.module.ts ---> 启动一个组件 app/app.component.ts

Hello Angular

三、完成组件的创建和使用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
1、创建组件和使用组件
①创建文件 app/test/test.component.ts
②将类装饰成一个组件类
import {Component} from '@angular/core'

@Component({
selector:'test',
template:`<h1>it is a test</h1>`
})

export class Demo01Component{
}
③使用组件
①到模块中声明
app.module.ts中,
import {TestComponent} from './test/test.component'

@NgModule({
declarations:[TestComponent]
})
②<test></test>

练习:(16:50 - 17:00)
demo02/demo02.component.ts
组件中渲染一个无序列表(5个列表)

将组件渲染AppComponent

四、Angular 中常见的指令

1
2
3
4
5
6
7
8
9
10
11
12
1、循环指令
Vue : <any v-for="tmp in list"></any>

Angular:
语法:
<any *ngFor="let tmp of list"></any>
<any *ngFor="let tmp of list;let myIndex=index"></any>

2、选择指令
Vue: <any v-if="表达式"></any>
angular:
<any *ngIf="表达式"></any>

五、常见指令

指令和组件的关系:

1
组件就是一个带有模板的指令!!!

1、多重分支判断

1
2
3
4
5
6
7
8
9
vue
v-if
v-else-if
v-else

<div [ngSwitch]="answer">
<p *ngSwitchCase="'a'"></p>
<p *ngSwitchDefault></p>
</div>

2、属性绑定

1
2
3
4
5
6
7
8
9
10
11
Vue:
<img v-bind:src="imgUrl"/>
<img :src="imgUrl"/>
<button :class="{myHightlight:true}"></button>
<h1 :style="{backgroundColor:myBG}"></h1>

Angular:
<img [src]="imgUrl"/>
<button [ngClass]="{myHightlight:true}"></button>
<h1 [ngStyle]="{backgroundColor:myBG}">
</h1>

3、事件绑定

1
2
3
4
5
6
7
8
Vue
<button v-on:click="handleClick"></button>
<button @click="handleClick"></button>
Angular
语法:
<any (eventName)="eventHandler()"></any>
举例:
<button (click)="handleClick()"></button>

4、双向数据绑定

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
Vue:
<input v-model="addr"/>
Angular:
<input [(ngModel)]="addr"/>

依赖注入:
将依赖的东西注入到指定的地方,让依赖可被使用
举例:AppModule依赖于FormsModule,
只需要在AppModule的imports数组写上FormsModule名称
就可以使用FormsModule所提供的东西。
好处:解耦,降低了耦合度

Angular中如果想要监听双向数据绑定数据的变化,提供一个事件 ngModelChange

注意事项:
①Angular中如果要想使用双向数据绑定,就必须指定模块依赖于FormsModule
②使用ngModelChange事件时,通过$event去传递用户当前所输入的信息
(ngModelChange)="handleChange($event)"

内置的指令:

1
2
3
4
5
6
7
8
9
*ngFor
*ngIf
*ngSwitchCase
*ngSwitchDefault
ngSwitch
[]
()
[(ngModel)]
{{}}

5、自定义指令

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
Vue中自定义指令:
Vue.directive('change',{
bind:function(el,binding){},
update:function(){},
unbind:function(){}
});
v-change
Angular中指令创建和使用

5.1 创建
import {Directive} from '@angular/core'

@Directive({
selector:'[test]'
})

export class TestDirective{
}

5.2 使用
①到模块中声明
app.module.ts
import {TestDirective} from '***'
@NgModule({
declarations:[TestDirective]
})
②作为标签的属性
<h1 test></h1>

5.3 得到调用指令的元素
①import {ElementRef} from '@angular/core'
②实例化
constructor(private el:ElementRef){}
③读取元素
this.el.nativeElement

5.4 指令调用时传参??
①<h1 test="123"></h1>
②在指令类的内部
import {Input} from '@angular/core'

@Input() test="";

this.test

补充:使用生命周期的处理函数?
①引入
import {OnDestroy} from '@angular/core'
②在定义类的时候 实现接口类
export class Test implements OnDestroy{
ngOnDestroy(){}
}

六、组件之间通信

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
Vue中组件通信的方式?
①props down
步骤1:发送
<son myName="zhangsan"></son>
步骤2:接收
Vue.component('son',{
props:['myName']
})
②events up(子-》父)
步骤1: 事件的绑定
methods:{
rcvMsg:function(msg){}
}
<son @customEvent="rcvMsg"></son>
步骤2:事件的触发(儿子)
this.$emit('customEvent',123);
③$refs $parent
④bus
Angular中组件通信?
1、props down
步骤1:发送
<son uName="zhangsan"></son>
步骤2:接收
import {Input} from '@angular/core'
@Input() uName="";
this.uName
2、events up
步骤1:事件和处理函数的绑定
定义一个方法
rcvMsg(msg){}
<son (toFatherEvent)="rcvMsg($event)">
</son>
步骤2:触发事件
子组件触发
import {Output,EventEmitter} from '@angular/core'

@Output() toFatherEvent = new EventEmitter();

this.toFatherEvent.emit('123');

我们是这样写 Angular 应用的:

1
2
3
4
用 Angular 扩展语法编写 HTML 模板,
用组件类管理这些模板,
用服务添加应用逻辑,
用模块打包发布组件与服务。

七、管道(pipe)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
管道是用来对数据进行筛选、过滤、格式化

Vue中过滤器:
<any>{{expression | filter(1,2) | filter2 }}</any>

Vue.filter('changeSex',function(arg,arg1,arg2){
return 处理后的结果
})

angular中管道:

过滤器的本质就是一个有参数有返回值的方法

语法:
<any>
{{expression | pipe1:'12':34 | pipe2}}
</any>

1、内置管道

常见内置管道:
uppercase/lowercase/date/number/slice

2、自定义管道
创建一个自定义管道:
import {Pipe,PipeTransform} from '@angular/core'

@Pipe({
name:'testNG'
})

export class TestPipe implements PipeTransform {
//value是竖杠前表达式执行的结果
//args通过调用管道时,冒号后边跟的参数
transfrom(value:any,...args:[]):any{
return ‘处理后的结果’
}

}

调用:
①声明
到模块中先引入再声明
②调用
和内置管道的用法是一样的,同样支持传参、多重过滤

八、服务 (依赖注入)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
服务 service:服务的本质是一个类,在服务类中封装的是经常用到的数据和方法。

常见的服务:日志类服务、心跳服务、网络请求服务。。。

1、服务的创建和使用
创建:
import {Injectable} from '@angular/core'

@Injectable()
export class UserService {
constructor(){}

checkUserLogin(){return true}
}

使用:
①需要给服务指定provider
在组件中或者模块中指定providers:[UserService]
②调用
import {UserService} from './***'

constructor(private myService:UserService){}

this.myService.checkUserLogin()

2、如何封装一个网络请求的服务

①创建服务的文件
②在服务中封装一个方法
sendRequest(myUrl:string){
return this.http.get(myUrl).map((response)=>
response.json()
)
}
③调用之前 首先指定providers
④到组件中,先引入,再实例化,再调用
this.myHS.sendRequest().subscribe((result)=>{
//result就是服务器端返回的结果!
})

与服务器端通信如果涉及的session,angular需要这么处理:
客户端
①发起请求 withCredentials:true
this.http.get(
myUrl,
{withCredentials:true}
)
服务器端:
①跨域header('Access-Control-Allow-Origin:http://localhost:3000');
②服务器允许接收凭证
header('Access-Control-Allow-Credentials:true');

服务创建和使用:
1、创建一个文件 test.service.ts
2、在文件中编写代码,装饰一个服务
@Injectable()
export class TestService{
showAlert(msg){
alert(msg);
}
}
3、 给模块或者组件,在providers属性对应的数组中 [TestService]

4、组件中要想使用服务中的方法
import {TestService} from '***'

constructor(private myService:TestService){}

this.myService.showAlert()

Angular 中开发模式:

1
2
3
4
5
6
7
8
我们是这样写 Angular 应用的:
用 Angular 扩展语法编写 HTML 模板,
用组件类管理这些模板,
用服务添加应用逻辑,
用模块打包发布组件与服务。

然后,我们通过引导根模块来启动该应用。
Angular 在浏览器中接管、展现应用的内容,并根据我们提供的操作指令响应用户的交互。

在 Angular 开发时,八大组成部分:

1
2
3
4
5
6
7
8
9
10
11
12
1、模块
2、组件
3、模板 自带的html标签+指令、绑定相关的ng的语法
4、元数据 告诉 Angular 如何处理一个类。
5、数据绑定
{{}} () [] [(ngModel)]
6、指令
三大类:组件、结构型、属性型
7、服务
封装一些数据和方法
8、依赖注入
就是将依赖的服务、模块注入到指定组件、模块中使用,提供了一种新的实例化的方式(解耦)

九、路由模块

路由模块:建立起 url 和页面之间的映射关系

1、实现 SPA 的基本步骤

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
Vue:
实现一个SPA基本思路:
①指定一个容器
<router-view></router-view>
②创建代码片段
创建组件
var Login = Vue.component('login-component',{
template:`<h1>登录页面</h1>`
})
③配置路由词典
new Vue({
router:new VueRouter({
routes:[
{path:'/myLogin',component:Login}
]
})
})
④测试
测试路由词典中 路由地址能否按照需求 正确加载所需要用到的页面

Angular:
①指定容器
<router-outlet></router-outlet>
②创建组件 (声明)
@Component({}) export class **
③配置路由词典
//a-module-routing
import {Routes,RouterModule} from '@angular/router'
import {LoginComponent} from './demo15_spa/login.component'

const routes:Routes = [
{path:'',component:LoginComponent}
.....
]

@NgModule({
import:[RouterModule.forRoot(routes)],
exports:[RouterModule]
})

export class AppRoutingModule{}

找到根模块:
import {AppRoutingModule} from './app.router'

@NgModule({
imports:[AppRoutingModule]
})
④测试

2、在 Angular 实现组件间的导航的方式

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Vue写法:
①可以直接修改地址栏(内部测试)
②可以通过js
this.$router.push('目的地的路由地址')
③routerLink
<router-link to="目的地的路由地址"></router-link>
Angular:
①直接修改地址栏
②js
import {Router} from '@angular/router'
constructor(private myRouter:Router){}
this.myRouter.navigateByUrl('url');
③ <a routerLink="地址"></a>

补充:实现前进和后退
import {Location} from '@angular/common'

constructor(private myLocation:Location){}

this.myLocation.back(); this.myLocation.forward();

3、参数的传递

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Angular:
3.1 发送
this.myRouter.navigateByUrl('myOC/123');

3.2 接收
① 配置接收方的路由地址
{path:'myOC'} ==> {path:'myOC/:price'}
② 接收参数
import {ActivatedRoute} from '@angular/router'

constructor(private myAR:ActivatedRoute){}

this.myAR.params.subscribe((result)=>{
//result.price
})

在Angular中 实现数据传输的方式:
①组件间通信
②跳转时指定参数
③与远程服务器端通信

4、路由嵌套

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
可以在SPA中某个组件中,根据url嵌套其它的组件
Vue中实现方式:
①在准备嵌套其它组件的,指定一个容器 <router-view></router-view>
②配置路由词典
{
path:'',
component:MailComponent,
children:[
{path:'inbox',component:***}
]
}

Angular中实现方式:
①指定容器
router-outlet
②配置子路由
{
path:'mail',
children:[
...
]
}

总结:在Angular中实现一个支持路由嵌套的SPA,
导航到对应的子路由对应的页面时,必须在携带父组件的地址
localhost:3000/mail/outbox
localhost:3000/mail/inbox

demo18_embed
mylogin.component.ts MyLoginComponent
mail.component.ts MailComponent
inbox.component.ts InboxComponent
outbox.component.ts OutboxComponent
①完成组件的创建和声明

②路由模块

5、路由守卫

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
路由守卫 RouteGuard,控制是否能够访问某一个url中所对应的组件!
鉴权的组件
用户登录的页面
。。。

如何使用路由守卫:
①创建一个服务
import {Injectable} from '@angular/core'
import {CanActivate} from '@angular/router'

@Injectable()
export class MailGuard implments CanActivate{

canActivate(){
return true/false
}
}
②给服务指定提供商
providers:[MailGuard]
③给路由词典中想要保护的路由指定canActivate
{
path:'mail',
canActivate:[MailGuard]
}

Vue中如果也想实现路由守卫:
const router = new VueRouter({ ... })

router.beforeEach((to, from, next) => {
// ...
})

https://router.vuejs.org/zh-cn/advanced/navigation-guards.html