ng1和ng2的部分对比----angular2系列(四)
前言:
angular2相比angular1做了革命性的改变。对于开发者来说,我们知道它框架的实现上改变极大。我们看到代码也能发现它写法上变化很大,似乎完全是另一个东西。
但是当我们真正去写下去的时候,又会发现,处处都有angular1的影子,处处都是angular1的概念。对,没错。angular始终是angular,换件“衣服”,还是angular。
最开始我第一眼看到angular2的代码的时候,是有点排斥的,怎么感觉就像是react的写法...而后,我自己亲手,写它的demo时候发现,这货还是原本的angular,一切都那么熟悉。
所以有angular1基础的同僚,完全不用排斥。下面来对比一部分两个版本的写法。
directive:
angular1 |
angular2 |
ng-app |
Bootstrapping |
<body ng-app="myapp"> ng1中初始化引导应用,通过ngApp属性定义应用,并通过定义ng-view属性渲染到相应dom |
import { bootstrap } from '@angular/platform-browser-dynamic';
import { AppComponent } from './app.component';
bootstrap(AppComponent);
ng2引导应用通过bootstrap类实例化,AppComponent的@Component的selector属性选择dom进行渲染 |
ng-class |
ngClass |
<div ng-class="{active: isActive}">
|
<div [ngClass]="{active: isActive}">
[class.active]指代的就是active类,最开始我一看到还以为是伪类的写法 |
ng-click |
click event |
<button ng-click="vm.toggleImage()"> |
<button (click)="toggleImage()"> |
ng-controller |
Component decorator |
<div ng-controller="MovieListCtrl as vm"> |
@Component({
|
ng-show or ng-hide |
[hidden] |
<h3 ng-show="vm.favoriteHero"> |
<h3 [hidden]="!favoriteHero"> 只是用[hidden]属性,没有[show]属性 |
ng-href |
[href] |
<a ng-href="angularDocsUrl">Angular Docs</a> |
@RouteConfig([ <a [href]="movies">Angular Docs</a> <a [routerLink]="['Movies']">Movies</a> [href] 对应的是路由配置里path链接, [routerLink] 对应的是路由name 。 |
ng-if |
*ngIf |
<table ng-if="movies.length"> |
<table *ngIf="movies.length"> |
ng-model |
ngModel |
<input ng-model="vm.favoriteHero"/> ng-model在angular1中是双向绑定指令 |
<input [(ngModel)]="favoriteHero" />
[()]在angular2中代表双向绑定, 也可以使用bindon-ngModel,推荐前者写法 |
ng-repeat |
*ngFor |
<tr ng-repeat="movie in vm.movies"> |
<tr *ngFor="let movie of vm.movies"> 如果不加*,只会遍历一个项 |
ng-src |
[src] |
<img ng-src="{{movie.imageurl}}">
|
<img [src]="movie.imageurl"> |
ng-style |
ngStyle |
<div ng-style="{color: colorPreference}">
|
<div [ngStyle]="{color: colorPreference}">
|
ng-switch |
ngSwitch |
<div ng-switch="vm.favoriteHero"> |
<span [ngSwitch]="favoriteHero"> |
Filters / Pipes:
angular1 |
angular2 |
currency |
currency |
|
<td>{{movie.price | currency}}</td> |
<td>{{133567 | currency:'USD':true}}</td> //$133,567 <td>{{133567 | currency:'RMB':true}}</td> //RMB133,567 属性值不支持¥,$等符号,必须按照USD,RMB这样写,否则不显示 |
date |
date |
<td>{{movie.releaseDate | date}}</td>
|
<td>{{movie.releaseDate | date}}</td>
|
filter |
none |
<tr ng-repeat="movie in movieList | filter: {title:listFilter}">
|
由于性能原因,ng2没有filter指令,需要在component用户自己定义过滤 |
json |
json |
<pre>{{movie | json}}</pre>
|
<pre>{{movie | json}}</pre>
和 JSON.stringify 功能相同 ,和 angular1 的 json 一样 |
limitTo |
slice |
<tr ng-repeat="movie in movieList | limitTo:2:0"> |
<tr *ngFor="let movie of movies | slice:0:2"> |
lowercase |
lowercase |
<div>{{movie.title | lowercase}}</div>
|
<td>{{movie.title | lowercase}}</td>
|
number |
number |
<td>{{movie.starRating | number}}</td>
|
<td>{{movie.starRating | number}}</td>
number 和 percent 属性值控制小数点后面的位数,只是写法让人看不懂,有谁知道为什么是这样? |
orderBy |
none |
<tr ng-repeat="movie in movieList | orderBy : 'title'"> |
也是由于性能问题,ng2不再提供此指令 |
Controllers / Components:
angular1 视图的模型和方法都在控制器(Controllers)里,angular2中建立这些在组件(Components)里。
angular1 |
angular2 |
currency |
currency |
|
<td>{{movie.price | currency}}</td> |
<td>{{133567 | currency:'USD':true}}</td> //$133,567 <td>{{133567 | currency:'RMB':true}}</td> //RMB133,567 属性值不支持¥,$等符号,必须按照USD,RMB这样写,否则不显示 |
IIFE(函数表达式) |
none |
|
在angular1中,我们经常定义一个立即调用函数表达式(或IIFE)在我们的控制器代码。 这让我们的控制器代码全局命名空间。 |
angular2中我们不需要担心这个问题, 因为我们使用ES 2015模块和模块处理我们的命名空间 |
Angular modules |
import |
angular.module("movieHunter", ["ngRoute"]);
|
import { Component } from '@angular/core';
angular2 使用es2015 modules ,每个代码文件都是模块,可以直接导入文件模块使用 |
Controller registration |
Component Decorator |
angular 在angular1中,注册模块下的控制器,通过以上方法。 第一个参数是控制器命名,第二个参数用字符串定义所有依赖,和一个控制器引用函数 |
@Component({
angular2中,我们通过@Component提供元数据,如模板和样式 |
Controller function |
Component class |
function MovieListCtrl(movieService) {
在angular1中,我们编写模型和方法在控制器函数里。 |
export class MovieListComponent {
在angular2中,我们创建一个组件类编写模型和方法 |
Dependency Injection |
Dependency Injection |
MovieListCtrl.$inject = ['MovieService']; ng1中,必须要对每个依赖进行注入 |
constructor(movieService: MovieService) {
在ng2中,constructor注入依赖,但是需要模块被当前组件或者当前组件的父组件引入依赖。 比如,当前组件引入依赖服务, import { MovieService } from './MovieService'; |
Style Sheets:
angular1 |
angular2 |
link tag |
link tag |
|
<link href="styles.css" rel="stylesheet" /> |
<link href="styles.css" rel="stylesheet" /> 属性值不支持¥,$等符号,必须按照USD,RMB这样写,否则不显示 StyleUrlsangular2 中 我们可以在@Component 中引入css, 此css默认会在当前组件形成一个独立的css作用域。 详情可以看此系列第三篇博客。“英雄之旅”见闻和小结----angular2系列(三) styleUrls: ['app/movie-list.component.css'], |
小结:
哎呀妈呀,写完累死宝宝了... 回顾了angular1和angular2,并进行了对比,还对遗漏过的知识点进行了补充学习。收获满满~
ng1和ng2的部分对比----angular2系列(四)的更多相关文章
- angular2系列教程(十)两种启动方法、两个路由服务、引用类型和单例模式的妙用
今天我们要讲的是ng2的路由系统. 例子
- angular2系列教程(一)hello world
今天我们要讲的是angular2系列教程的第一篇,主要是学习angular2的运行,以及感受angular2的components以及模板语法. 例子 这个例子非常简单,是个双向数据绑定.我使用了官网 ...
- RX系列四 | RxAndroid | 加载图片 | 提交表单
RX系列四 | RxAndroid | 加载图片 | 提交表单 说实话,学RxJava就是为了我们在Android中运用的更加顺手一点,也就是RxAndroid,我们还是先一步步来,学会怎么去用的比较 ...
- 网络结构解读之inception系列四:Inception V3
网络结构解读之inception系列四:Inception V3 Inception V3根据前面两篇结构的经验和新设计的结构的实验,总结了一套可借鉴的网络结构设计的原则.理解这些原则的背后隐藏的 ...
- Paddle Graph Learning (PGL)图学习之图游走类模型[系列四]
Paddle Graph Learning (PGL)图学习之图游走类模型[系列四] 更多详情参考:Paddle Graph Learning 图学习之图游走类模型[系列四] https://aist ...
- 前端构建大法 Gulp 系列 (四):gulp实战
前端构建大法 Gulp 系列 (一):为什么需要前端构建 前端构建大法 Gulp 系列 (二):为什么选择gulp 前端构建大法 Gulp 系列 (三):gulp的4个API 让你成为gulp专家 前 ...
- Netty4.x中文教程系列(四) 对象传输
Netty4.x中文教程系列(四) 对象传输 我们在使用netty的过程中肯定会遇到传输对象的情况,Netty4通过ObjectEncoder和ObjectDecoder来支持. 首先我们定义一个U ...
- S5PV210开发系列四_uCGUI的移植
S5PV210开发系列四 uCGUI的移植 象棋小子 1048272975 GUI(图形用户界面)极大地方便了非专业用户的使用,用户无需记忆大量的命令,取而代之的是能够通过窗体.菜单 ...
- WCF编程系列(四)配置文件
WCF编程系列(四)配置文件 .NET应用程序的配置文件 前述示例中Host项目中的App.config以及Client项目中的App.config称为应用程序配置文件,通过该文件配置可控制程序的 ...
随机推荐
- 奇怪的UnexpectedRollbackException异常
今天在使用一个原来常用的功能的时候,突然发现在某些场景下会报异常,内容如下: 通过断点调试发现一路都很顺畅,就是在从controller层返回前段的时候会报该异常,没办法,只能通过排除法定位问题,后来 ...
- 关于OpenStack的学习路线及相关资源汇总
首先我们想学习openstack,那么openstack是什么?能干什么?涉及的初衷是什么?由什么来组成?刚接触openstack,说openstack不是一个软件,而是由多个组件进行组合,这是一个更 ...
- Android内存清理
直接上图吧! 获取文件大小 ,清理文件工具类 public class DataCleanManager { public static String getTotalCacheSize(Contex ...
- 《Linux内核设计与实现》读书笔记 第三章 进程管理
第三章进程管理 进程是Unix操作系统抽象概念中最基本的一种.我们拥有操作系统就是为了运行用户程序,因此,进程管理就是所有操作系统的心脏所在. 3.1进程 概念: 进程:处于执行期的程序.但不仅局限于 ...
- CYQ.Data V5 MDataTable 专属篇介绍
前言 以前一两个月才出一篇,这三天有点变态地连续1天1篇(其实都是上周末两天写好的存货). 短期应该没有新的和此框架相关的文章要写了,这应该是最后一篇,大伙且看且珍惜. 前两篇讲数据库读写分离和分布式 ...
- ABP理论学习之功能管理
返回总目录 本篇目录 介绍 功能类型 定义功能 检查功能 功能管理者 版本说明 介绍 大多数的Saas(多租户)应用都有不同 功能的 版本(包).因此,他们可以给租户(客户)提供不同的 价格和功能选项 ...
- 《CLR.via.C#第三版》第二部分第12章节 泛型 读书笔记(六)
终于讲到泛型了.当初看到这个书名,最想看的就是作者对泛型,委托,反射这些概念的理解.很多人对泛型的理解停留在泛型集合上,刚开始我也是,随着项目越做越多,对待泛型的认识也越来越深刻. 泛型的概念:泛型是 ...
- ReactNative与NativeScript对比报告
综合这段时间对ReactNative(下称RN)和NativeScript(下称NS)的简单学习了解,分别从不同方面分析对比二者的优缺点. 页面结构 NS一个页面的目录结构: RN的一个页面一般就是一 ...
- Module Zero之角色管理
返回<Module Zero学习目录> 角色实体 角色管理者 多租户 角色实体 角色实体代表了该应用的一个角色.它应该派生自AbpRole类,如下所示: public class Role ...
- 搭建LNAMP环境(六)- PHP7源码安装MongoDB和MongoDB拓展
上一篇:搭建LNAMP环境(五)- PHP7源码安装Redis和Redis拓展 一.安装MongoDB 1.创建mongodb用户组和用户 groupadd mongodb useradd -r -g ...