Angular2入门--架构总览


Posted in Javascript onMarch 29, 2017

大致介绍

在3月23日,Angular4正式发布(没有3)。似乎现在学Angular2又晚了,又晚一步-_-||。Angular2在Angular1的基础上有了较大的改变。之前向一个同学(之前学过Angular1)问一个Angular2的问题,他反问到这是Angular代码? 可见Angular1->Angular2的变化有多大。先来看看Angular2的架构

核心模块

一个完整的Angular应用主要由六个重要部分组成:组件、模板、指令、服务、依赖注入和路由

他们之间的关系:

Angular2入门--架构总览

从图中可以看出:

1、与用户交互的是模板视图,模板和组件类共同组成组件

2、路由是控制组件的创建和销毁,从而驱使界面切换

3、指令和模板相关联,扩展了模板的语法

4、服务是封装若干个功能逻辑的单元,通过依赖注入引入组件内部

组件

Angular框架是基于组件设计,组件负责控制屏幕上的一小块区域,例如网页的导航栏就是一个组件

一个组件的代码:

import { Component, Input } from '@angular/core';
import { Hero } from './hero';
@Component({
 selector: 'my-hero-detail',
 template: `
 <div *ngIf="hero">
  <h2>{{hero.name}} details!</h2>
  <div><label>id: </label>{{hero.id}}</div>
  <div>
  <label>name: </label>
  <input [(ngModel)]="hero.name" placeholder="name"/>
  </div>
 </div>
})
export class HeroDetailComponent {
 @Input()
 hero: Hero;
}

模板

我们通过组件的自带的模板来定义组件视图。模板以 HTML 形式存在,告诉 Angular 如何渲染组件。

例如上面组件中的@Component中就是模板

@Component({
 selector: 'my-hero-detail',
 template: `
 <div *ngIf="hero">
  <h2>{{hero.name}} details!</h2>
  <div><label>id: </label>{{hero.id}}</div>
  <div>
  <label>name: </label>
  <input [(ngModel)]="hero.name" placeholder="name"/>
  </div>
 </div>
})

指令

指令和模板的关系密切,指令可以与DOM进行灵活交互,可以改变样式也可以修改DOM。一般的指令都作用在已有的DOM元素上

1、修改DOM

<button *ngIf="canEdit">编辑</button>

当canEdit为true时,button会显示,否则,button隐藏

2、改变元素样式

<button [ngStyle]="setStyles()">编辑</button>

setStyles()是一个函数,可以通过这个函数修改元素的样式

服务

服务是封装单一功能的单元,常被引用于组件内部,作为组件的功能扩展。它可以是一个简单的字符串或是JSON数据,也可以是一个函数甚至是一个类

组件本身不从服务器获得数据、不进行验证输入,也不直接往控制台写日志。 它们把这些任务委托给服务。

一个简单的服务(包含一个类):

export class Hero {
 id: number;
 name: string;
}

依赖注入

通过依赖注入机制,服务等模块可以被引入到任何一个组件中,而开发者无需关心这些模块是如何被初始化的。因为Angular已经帮你处理好了,包括本模块本身依赖的其他模块也会被初始化

路由

路由它把浏览器中的URL看做一个操作指南, 据此导航到一个由客户端生成的视图,并可以把参数传给支撑视图的相应组件,帮它决定具体该展现哪些内容。 我们可以为页面中的链接绑定一个路由,这样,当用户点击链接时,就会导航到应用中相应的视图。 当用户点击按钮、从下拉框中选取,或响应来自任何地方的事件时,我们也可以在代码控制下进行导航。 路由器还在浏览器的历史日志中记录下这些活动,这样浏览器的前进和后退按钮也能照常工作。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
ajaxControlToolkit AutoCompleteExtender的用法
Oct 30 Javascript
jQuery EasyUI API 中文文档 - Dialog对话框
Nov 15 Javascript
刷新页面的几种方法小结(JS,ASP.NET)
Jan 07 Javascript
JavaScript中用于四舍五入的Math.round()方法讲解
Jun 15 Javascript
jQuery基础_入门必看知识点
Jul 04 Javascript
javascript封装addLoadEvent实现页面同时加载执行多个函数的方法
Jul 25 Javascript
jQuery 判断是否包含在数组中Array[]的方法
Aug 03 Javascript
详解利用exif.js解决ios手机上传竖拍照片旋转90度问题
Nov 04 Javascript
微信小程序使用checkbox显示多项选择框功能【附源码下载】
Dec 11 Javascript
关于redux-saga中take使用方法详解
Feb 27 Javascript
详解一个基于套接字实现长连接的express
Mar 28 Javascript
localstorage实现带过期时间的缓存功能
Jun 28 Javascript
整理关于Bootstrap表单的慕课笔记
Mar 29 #Javascript
AngularJS中$http的交互问题
Mar 29 #Javascript
Angular2开发——组件规划篇
Mar 28 #Javascript
jquery实现静态搜索功能(可输入搜索文字)
Mar 28 #jQuery
jQuery插件FusionCharts绘制的2D帕累托图效果示例【附demo源码】
Mar 28 #jQuery
关于Node.js中Buffer的一些你可能不知道的用法
Mar 28 #Javascript
使用JavaScriptCore实现OC和JS交互详解
Mar 28 #Javascript
You might like
浅析php fwrite写入txt文件的时候用 \r\n不能换行的问题
2013/08/06 PHP
详解PHP中的null合并运算符
2015/12/30 PHP
php parse_str() 函数的定义和用法
2016/05/23 PHP
高性能WEB开发 flush让页面分块,逐步呈现 flush让页面分块,逐步呈现
2010/06/19 Javascript
关于html+ashx开发中几个问题的解决方法
2011/07/18 Javascript
Google的跟踪代码 动态加载js代码方法应用
2012/11/12 Javascript
JS文本框不能输入空格验证方法
2013/03/19 Javascript
jQuery基本选择器选择元素使用介绍
2013/04/18 Javascript
js 页面元素的几个用法总结
2013/11/18 Javascript
Angularjs 基础入门
2014/12/26 Javascript
javascript去除字符串左右两端的空格
2015/02/05 Javascript
javascript发送短信验证码实现代码
2015/11/12 Javascript
js实现滚动条滚动到页面底部继续加载
2015/12/19 Javascript
理解JS事件循环
2016/01/07 Javascript
javascript对象的相关操作小结
2016/05/16 Javascript
浅谈js内置对象Math的属性和方法(推荐)
2016/09/19 Javascript
基于vue中keep-alive缓存问题的解决方法
2018/09/21 Javascript
浅谈React碰到v-if
2018/11/04 Javascript
微信小程序之高德地图多点路线规划过程示例详解
2021/01/18 Javascript
Python面向对象基础入门之编码细节与注意事项
2018/12/11 Python
Python数据可视化处理库PyEcharts柱状图,饼图,线性图,词云图常用实例详解
2020/02/10 Python
python读取图片的几种方式及图像宽和高的存储顺序
2020/02/11 Python
python图片验证码识别最新模块muggle_ocr的示例代码
2020/07/03 Python
如何编写python的daemon程序
2021/01/07 Python
求职自荐信怎么写
2014/03/06 职场文书
人事任命书范文
2014/06/04 职场文书
销售竞赛活动方案
2014/08/23 职场文书
办公室班子四风问题对照检查材料
2014/10/04 职场文书
三好学生评语大全
2014/12/29 职场文书
教师节感想
2015/08/11 职场文书
奶茶店的创业计划书该怎么写?
2019/07/15 职场文书
人生哲理妙语30条:淡写流年,笑过人生
2019/09/04 职场文书
JavaScript控制台的更多功能
2021/04/28 Javascript
利用Pycharm连接服务器的全过程记录
2021/07/01 Python
mysql使用instr达到in(字符串)的效果
2022/04/03 MySQL
javascript进阶篇深拷贝实现的四种方式
2022/07/07 Javascript