大咖微课 | 直面Angular2系列课第二期开讲

1.背景介绍:Angular1.x与Angular2


近年来,Web 开发技术的发展日新月异,各种框架层出不穷。在这样的大背景之下,2010年10月,Google 首次发布了自己的 Web 开发框架,名为 AngularJS,也叫 Angular,或者简称为 ng。




Angular 刚一发布就引起了强烈的关注,它首次提出的“双向数据绑定”的概念受到了众多开发者的喜爱。当然,也有很多人对此持有保留意见。但是无论如何,Angular 所提出来的众多独创性的概念深深影响了 Web 技术的发展进程。例如,当前市面上相当多的 Web 框架都已经支持“数据绑定”的概念,有一些支持单向绑定,有一些支持双向绑定,Angular 的影响力之强大可见一斑。


在 Google 内部有非常多的产品都在使用 Angular,在国内,也有非常多的企业正在使用 Angular1.x 开发自己的应用,包括移动 APP,其中有很多行业巨头。




2014年9月,Angular 团队在 ng-europe 会议上公开宣布了第二个大版本的开发计划,也就是大家熟知的 Angular2,与此对应,之前的版本就称为 Angular 1.x了。


Angular2 依然保持了最初的核心设计理念,但是与 Angular 1.x 相比,在各种语法细节上发生了大幅度的修改。



详细的情况在后面的第三小节“ Angular2 有哪些重要变化?”中解释。从整体上看,Angular2 变得更加简洁,因为它的核心概念只有一个,那就是追求彻底的“组件化(Component)”。


2.每一个框架都有一个核心灵魂


当我们谈论 Spring 的时候,你脑海里一定会自动跳出 IOC、DI 这样的概念。显然,“控制反转”、“依赖注入”就是 Spring 的核心灵魂。


当我们谈论 Hibernate 或者 Mybatis 的时候,你首先想到的一定是 ORM(实体关系映射),它解决了关系模型和 OO 模型之间的数据结构映射问题。


当我们谈论 jQuery 的时候,你想到的一定是 DOM 操作以及网络上无数的开源控件。很显然,DOM 操作就是 jQuery 的核心灵魂,它帮我们屏蔽了浏览器兼容性问题,并且提供了业务开发过程中所需要的各种UI控件。


当我们谈论 Angular 1.x 的时候,你想到了什么?呃,等一等,想到的东西有点多,有时候什么都想不起来。概念庞杂而无法把握,这就是 Angular 1.x 存在的最大问题。


每一个成功的框架都会有一个核心灵魂,这个核心灵魂必须能解决实际开发中的一个痛点。既然是核心灵魂,最好有且只有一个,否则就会给使用者带来很大的学习压力。在这一方面,Angular1.x 是一个反面教材。


因为它的特性比较多,其中最核心的4大特性分别是:

  • 模块化

  • MVC

  • 双向数据绑定

  • 指令


如果再加上一些琐碎的细节,如 $scope、脏值检测、依赖注入、路由、表单校验等等,整体上给人的感觉就是过于琐碎,没有一个核心灵魂能统摄一切。

Angular 团队也意识到了这一点,因此,Angular2 在设计之初就简化了整体的概念模型。Angular2 的核心灵魂只有一个,那就是组件化(Component),而其它那些细碎的东西,比如 Service、Route、Pipe,都是 utils 而已。因此,在使用 Angular2 的时候,开发者只要学会使用 Coponent 就解决了一大半问题。

大道至简,LESS is MORE。

3.Angular2 有哪些重要变化?

有了 Component 这个统摄全局的概念之后,我们来看看与 Angular 1.x 相比 Angular2 发生了什么变化。

第一点:Angular2 删掉了 $scope 的概念

在 Angular 1.x 里面,$scope 是一个相当强大又相当可怕的东西,由于在很多需要回调的场景之下,脏值检测机制无法感知到 $scope 上发生的变化,因此经常需要开发者自己手动调用 $apply() 方法。典型的场景有:事件回调、setTimeout 回调、Ajax 回调等等。Angular2 响应社区的强烈呼吁,删除(或者说隐藏)了 $scope 的概念,开发者不再需要感知到它的存在。另外,Angular2 在底层引入了 zone.js,所以即使在各种回调函数中修改数据模型也不需要手动调用 $apply() 方法了。


第二点:删掉了 ng-controller 指令

这就意味着 Controller 不再是一个独立的组件,它合并到了 Component 内部。这是一个非常大的演进,因为从大量的实战经验来看,在复杂的业务逻辑中复用 Controller 几乎是不可能的。在其它同类的前端框架里面也有类似的处理手法,例如 Backbone 虽然也强调 MVC 的概念,但是它也没有定义单独的 Controller 类,Controller 也是合并在 View 里面编写的。


第三点:大幅度演进了脏值检测机制

众所周知,“双向数据绑定”之所以能运行,是因为 Angular 底层有“脏值检测”这么一个神奇的机制。而实际上 Angular 1.x 里面的脏值检测机制的运行效率非常差,这就是为什么大家一直在抱怨绑定的对象不能太多、太深的原因。Angular2 大幅度演进了这一机制,不仅引入了单向绑定,还增加了各种检测策略,例如:只检测一次、利用 JIT 动态生成脏值检测代码等等。毫无疑问,有了这些工具之后,数据绑定效率不再是问题。


第四点:嵌套路由

Angular 1.x 里面有一个非常讨厌的问题,框架内置的路由机制不支持嵌套使用,这就导致开发者在日常的开发过程中不得不依赖于第三方的 ui-router 库。Angular2 没有这个问题了,因为 Angular2 的路由是基于 Component 的,天然支持嵌套。


第五点:依赖注入机制演进

Angular2 中的依赖注入写法与 Java 中的注解(Annotation)非常类似,如果你熟悉 Spring 注解的用法,那么使用 Angular2 的依赖注入几乎没有学习成本。当然,概念上是有区别的,Angular2 中叫 Decorator(装饰器),更加贴近 Python 里面的 Decorator 的概念。


第六点:框架整体上基于 TypeScript 开发

这是最大的一个变更,有很多人担忧这样是否会带来比较大的学习成本,实际的情况并非如此。因为 TypeScript 的语法与 Java 或者 C# 非常类似,因此对于从后端转过来的开发者来说,学习这门语言几乎是没有难度的。


还有一个重要的方面需要大家注意:TypeScript 是 Microsoft 开发的一门语言,Google+Microsoft 这样的组合会产生多么强大的推动力,大家可以想象。Google 和 Microsoft 本身都是重要的浏览器厂商,Chrome 和 IE 加起来的市场份额占据了一大半的市场份额,未来如果两款浏览器内建 TypeScript 引擎,很显然 TypeScript 和 Angular 的前景将会一片光明。这一优势是大量的同类技术框架根本无法企及的,因此大家在做技术选型的过程中需要综合考虑这些情况作出理性的决策。


4.我从哪里开始学习Angular2?


直面Angular2系列课第二期

“Hello,Angular 2”


开课时间:12-20 20:00 | 时长:1小时



主讲嘉宾


郝冠军

微软最有价值专家

毕业于北京航空航天大学,软件工程硕士学位

具有十年以上的开发与培训经验

对ASP.NET和Visual Studio Code有着深入的研究

多家著名企业培训讲师,微软招募组组长,博客园博主

著有畅销书《ASP.NET本质论》



内容介绍


实现 Hello, Angular 2 组件

使用 Module 组织模块

获取 Angular 2

使用Typing 获取类型定义

编译 Angular 2 的三种方式

模块加载器之一 System.js

模块加载器之二 Webpack

使用 AOT 实现预编译

课程总结

互动问答环节


报名入口


dotNET跨平台粉丝的福利来了!

本期微课系付费课程

点击阅读原文获取课程优惠券

使用优惠券即可免费听课

数量有限!先到先得!



.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/327490.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java实现遍历树形菜单方法——struts.xml实现

<?xml version"1.0" encoding"UTF-8" ?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd"> <struts><package …

HashMap在java并发中如何发生死循环

转载自 HashMap在java并发中如何发生死循环 在多线程环境中&#xff0c;使用HashMap进行put操作时会引起死循环&#xff0c;导致CPU使用接近100%&#xff0c;下面通过代码分析一下为什么会发生死循环。 首先先分析一下HashMap的数据结构&#xff1a;HashMap底层数据结构是有一…

计算机和影视结合专业,计算机专业专业建设总结与典型案例2.5微电影拍摄与后期制作(影视拍摄与后期制作技术)课....

计算机专业专业建设总结与典型案例2.5微电影拍摄与后期制作(影视拍摄与后期制作技术)课. (11页)本资源提供全文预览&#xff0c;点击全文预览即可全文预览,如果喜欢文档就下载吧&#xff0c;查找使用更方便哦&#xff01;9.9 积分微电影拍摄与后期制作(影视拍摄与后期制作技术)…

SpringBoot +Vue前后端分离(笔记)

前后端分离简介 前后端分离 前后端分离就是将⼀个应⽤的前端代码和后端代码分开写&#xff0c;为什么要这样做&#xff1f; 如果不使⽤前后端分离的⽅式&#xff0c;会有哪些问题&#xff1f; 传统的 Java Web 开发中&#xff0c;前端使⽤ JSP 开发&#xff0c;JSP 不是由后…

JAVA代码实现按列表中元素的时间字段排序 左联表后缺失数据 多字段进行排序

Data ApiModel(value "EstateListVo", description "小区列表") public class EstateListVo implements Serializable {private static final long serialVersionUID 4969589185044044369L;ApiModelProperty("小区ID")private Long estateId;…

.NET Core下使用gRpc公开服务(SSL/TLS)

一、前言 前一阵子关于.NET的各大公众号都发表了关于gRpc的消息&#xff0c;而随之而来的就是一波关于.NET Core下如何使用的教程&#xff0c;但是在这众多的教程中基本都是泛泛而谈&#xff0c;难以实际在实际环境中使用&#xff0c;而该篇教程以gRpc为主&#xff0c;但是使用…

HashMap jdk1.7源码阅读与解析

转载自 HashMap源码阅读与解析 一、导入语 HashMap是我们最常见也是最长使用的数据结构之一&#xff0c;它的功能强大、用处广泛。而且也是面试常见的考查知识点。常见问题可能有HashMap存储结构是什么样的&#xff1f;HashMap如何放入键值对、如何获取键值对应的值以及如何…

如何兼容html在不同分辨力的问题,现代教育技术练习题

2009年秋期《现代教育技术》理论基础知识综合练习题一、单项选择题1、教育技术是关于学习过程和学习资源的()五个领域的理论与实践。A&#xff0e;开发、应用、购置、建构、评价B&#xff0e;组织、设计、实验、管理、辅导C&#xff0e;开发、应用、管理、设计、评价D&#xff…

2013蓝桥杯-B-省赛-六-三部排序

六、三部排序 package com.markerhub;public class TEST { // 负数都靠左端&#xff0c;正数都靠右端&#xff0c;0在中部static void sort(int[] x) //解题技巧&#xff1a;边猜测、边验证、逐步推理逻辑//极限思维 全是0 --> p //填空题&#xff1a;一般就一行代码…

java实现加密电话号码,有具体的加密流程注释

闲着没事做&#xff0c;正好有一位哥们让帮他看个写个逻辑题&#xff0c;我就顺便写了下&#xff01; 此题主要是加密一个数字类型的电话号码&#xff0c;具体加密流程如下&#xff1a; * 将一串数字进行加密 * 加密规则&#xff1a;先把这串数字降序&#xff0c;然后将每个…

.NET项目版本号的小随笔

【题外话】 一直以来都对.NET项目中的几个版本号&#xff08;AssemblyVersion、AssemblyFileVersion、AssemblyInformationalVersion&#xff09;以及版本号中的Revision和Build有疑问&#xff0c;今儿抽了点时间看了几篇文章&#xff0c;整理一下与大家一起分享下。 【一、Ass…

Java实现最电话号码的简单加密源码

废话已经在 java实现加密电话号码&#xff0c;有具体的加密流程注释 这里面说了&#xff0c;这篇文章我就直接上代码了&#xff01; 请看&#xff1a; /** * Title: TestMain.java * Package org.test * Description: TODO该方法的主要作用&#xff1a; * author A18ccms A1…

进程和线程关系及区别

转载自 进程和线程关系及区别 1.定义 进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位. 线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只…

铜仁学院计算机报名,铜仁学院2012年3月全国计算机等级考试报名时间通知

2012年3月全国计算机等级考试有关事宜的通知各系(部)、现代教育技术中心、计财处&#xff1a;2012年3月全国计算机等级考试将于2012年3月24日&#xff0d;25日举行&#xff0c;按照教育部考试中心和贵州省考试中心的要求&#xff0c;我院计算机考试报名准备工作从2011年12月1日…

2013蓝桥杯-B-省赛-七、错误票据

七、错误票据 package com.markerhub;import java.util.Scanner; import java.util.ArrayList; import java.util.Collections;public class TEST { //解题思路&#xff1a;枚举public static void main(String[] args) {Scanner sc new Scanner(System.in);int N sc.nextI…

Windows.etc\hosts文件

Windows.etc\hosts文件 ZC&#xff1a;就是将 后面的项 重定位到 前面的项 1、目录&#xff1a;"C:\Windows\System32\drivers\etc" 文件&#xff1a;"C:\Windows\System32\drivers\etc\hosts" 2、c__Windows_System32_drivers_etc_hosts的作用 - Sharpe…

Java多线程:实现方式Thread与Runnable

转载自 Java多线程:实现方式 在Java中, 多线程的实现有两种方式&#xff1a;扩展java.lang.Thread类实现java.lang.Runnable接口 方法1 /** * Description: 继承Thread类, 实现多线程. * author snoopy * blog http://blog.csdn.net/huang_xw */ package basic.a_start; …

java实现邮件发送准备工作(前期配置)

本文主要用的邮件客户端是&#xff1a;office 2007的outlook,服务器是apache-james-2.3.2&#xff0c;首先我们来配置一下这个james服务器: 1.将james服务器解压到硬盘目录下&#xff0c;注意目录不能有中文&#xff0c;如e:盘下 2.修改apps/james/sar-inf目录下的confi…

计算机在轻化工程中的应用,计算机在轻化工程专业中的应用-中国大学mooc-题库零氪...

第一章 试验设计与统计学基础第一章单元测验1、1. 统计学是一门收集、整理、()和解释数据的科学。A、A、扩大B、B、传递C、C、增加D、D、分析2、3. ()最早提出试验设计的理论。A、A、Francis GaltonB、B、Karl PearsonC、C、Rinald FisherD、D、William Gosset3、4. 用来描述样…

JwtFilter---解决其中的跨域问题

JwtFilter 第五步&#xff1a;定义jwt的过滤器JwtFilter。 这个过滤器是我们的重点&#xff0c;这里我们继承的是Shiro内置的AuthenticatingFilter&#xff0c;一个可以内置了可以自动登录方法的的过滤器&#xff0c;有些同学继承BasicHttpAuthenticationFilter也是可以的。 …