【JS-10-angular有哪些优缺点?】
分享人:聂义中
目录
1.背景介绍
2.知识剖析
3.常见问题
4.解决方案
5.编码实战
6.扩展思考
7.参考文献
8.更多讨论
1.背景介绍
angular有哪些优缺点之前,简单的介绍一下什么是angular。
记得在最开始学习前端知识的时候,了解到前端三个基础html、CSS、JavaScript,他们可以简单的 表示为结构、样式和行为。
jQuery实质上就是提供了一些前端常用的,针对元素的处理的简便写法,可以把它看作一个JS的工具包。
Angular则是一个MVVM框架。
要说清楚什么是MVVM框架,需要了解MVC框架,了解MVC框架,需要了解一下前端开发的历史。
前端开发的历史和趋势
什么是前端?什么是后端?
前端:针对浏览器的开发,代码在浏览器运行
后端:针对服务器的开发,代码在服务器运行
互联网发展的早期,前后端开发是一体的,前端代码是后端代码的一部分。
1、后端收到浏览器的请求
2、生成静态页面
3、发送到浏览器
所以最初的网站是没有样式,更没有行为互动,只有结构,光秃秃的html。但在那个时候已经是很伟大的很先进的东西。
那时的网站开发,采用的是后端 MVC模式。
1、Model(模型层):提供/保存数据
2、Controller(控制层):数据处理,实现业务逻辑
3、View(视图层):展示数据,提供用户界面
前端只是后端 MVC的 V。(切图仔的由来?)
那时的前端工程师,实际上是模板工程师,负责编写页面模板,比如我们现在写的静态页面。
后端代码读取模板,替换变量,渲染出页面。
Ajax技术诞生,改变了一切。
2004年:Gmail
2005年:Google地图
前端不再是后端的模板,可以独立得到各种数据。
因为Ajax是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。
Ajax技术促成了 Web2.0的诞生。
Web1.0:静态网页,纯内容展示
Web2.0:动态网页,富交互,前端数据处理
从那时起,前端变得复杂了,对前端工程师的要求越来越高。
前端 MVC框架
前端通过 Ajax得到数据,因此也有了处理数据的需求。
前端代码变得也需要保存数据、处理数据、生成视图,这导致了前端 MVC框架的诞生
2010年,Backbone.js
Backbone将前端代码分成两个基本部分。
Model:管理数据
View:数据的展现
没有 C。因为,前端 Controller与后端不同。
不需要,也不应该处理业务逻辑
只需要处理页面逻辑,响应用户的一举一动,也就是和用户的交互
所以,前端 Controller相对比较简单。Backbone没有 C,只用事件来处理页面逻辑。
Router
前端还有一种天然的方法,可以切换视图,那就是 URL。
通过 URL切换视图,这就是 Router(路由)的作用。(html、js、angular)
前端 MVVM框架
另一些框架提出 MVVM模式,用 ViewModel代替 Controller。
Model
View
View-Model:简化的 Controller,唯一作用就是为 View提供处理好的数据,不含其他逻辑。
本质:view绑定 view-model,视图与数据模型强耦合。数据的变化实时反映在 view上,不需要手动处理。
MVC、MVVM、MVW,这里重点理解一下MVVM。
Mmodel模型
Vview视图
VMviewmodel视图的模型
Ppresenter展示器
Ccontroller控制器
Wwhatever随意
View视图 通俗易懂。就是前端的 HTML, CSS和 与 HTMLCSS有关的JS代码。 写一个Form表格,由 HTML架起,CSS做美化,JS来进行动画控制。
Model模型。简单说是起到连接服务器,和商业逻辑的形成。 这里面很多需要异步处理,并且有需求独立更新。因此,必须和视图分离。
而连接上面这两者的就是 ViewModal试图模型。 这里只做连接,并不起到控制。保证独立性。在多个 View和多个 Modal之前做到很好的桥梁的作用。
P起到的作用更多是展示,部分控制,换句话说 Angular里面那么多 ng-show后面的代码都可以理解为 P。
C起到的主体控制。比如读取 M的数据,然后插入一个模块到 V视图里。 如果用 Angular来解读,Controller就是 C。
W则不分的那么具体。更为灵活。
前端可以做到:
读写数据
切换视
用户交互
这意味着,网页其实是一个应用程序。
SPA=Single-pageapplication
2010年后,前端工程师从开发页面,变成了开发“前端应用”(跑在浏览器里面的应用程序)。
Angular
Google公司推出的 Angular是最流行的 MVVM前端框架。
它的风格属于 HTML语言的增强,核心概念是双向绑定。
Vue
Vue.js是现在很热门的一种前端 MVVM框架。
它的基本思想与 Angular类似,但是用法更简单,而且引入了响应式编程的概念
React
React是从Facebook起源的最著名的库。它使你的前端非常舒适,是一个非常独特的客户端库。
React.JS的核心目标是使前端能够高效开发和重用声明的插件。
回到angular
Angular目前有两个比较大的版本,一个是 1.X,一个是 5.0,对于 2.0以下的版本统称为 AngularJS,从 2.0版本开始称为 Angular。
那么AngularJS有哪些优点与缺点呢?
2.知识剖析
AngularJS的优点
1.良好的应用程序结构:
通常情况下,我们编写 JavaScript没有明确的结构。虽然在编写小应用程序的时候没有问题,但这显然是不适合于大规模的应用程序。
使用 AngularJS,您可以通过MVC(模型 -视图 -控制器)或MVVM(模型 -视图 -视图模型)模式来组织源代码。
AngularJS是一个 MVW框架,其中W代表可以用于任何项目。你可以组织你的代码模块,它可显著提高应用程序的可测试性和可维护性。数据、业务逻辑、视图的分离。
2.双向数据绑定
数据绑定肯定是 AngularJS最佳功能之一。
你可以声明绑定的模型到 HTML元素。当模型发生变化时,视图会自动更新,反之亦然。 这可以减少大量的传统样板代码,保持模型和视图同步。
3.指令
自定义Directive,比jQuery插件还灵活,但是需要深入了解Directive的一些特性,简单的封装容易,复杂一点官方没有提供详细的介绍文档, 我们可以通过阅读源代码来找到某些我们需要的东西,如:在directive使用 $parse;
4.HTML模板
AngularJS使用 HTML模板,这使事情变得简单,并允许设计人员和开发人员同时工作。
设计人员可以按照通常的方式创建用户界面,而开发人员可以使用声明性绑定语法很容易配合不同的UI组件的数据模型。
5.依赖注入
ng模块化比较大胆的引入了Java的一些东西(依赖注入),能够很容易的写出可复用的代码,对于敏捷开发的团队来说非常有帮助, 我们的项目从上线到目前,UI变化很大,在摸索中迭代产品,但是js的代码基本上很少改动。
AngularJS的缺点
1.性能
双向数据绑定是一把双刃剑。随着组件增加,项目越来越复杂,双向数据绑定带来性能问题。
双向数据绑定是如何影响性能的?在JavaScript(ES5)中,并没有实现当变量或对象改变时发出通知的功能,Angular的实现方法被叫做“Dirty-checking(脏检查机制)”,通过跟踪数据的改变再动态更新用户界面(UI)。 在Angular的作用域中任何操作的执行都会引发Dirty-checking,随着绑定数量的增加性能就会越低。
2.Angular2.0推翻重做使得目前不宜采用此框架
Angular1.x版本其实是个比较旧的东西了,现在看来有些理念过时了,比如依赖注入、自己独特的模块化,这些东西其实在ES6下已经很好地被解决了。 Angular的2.0几乎是一个推翻重做的框架,估计不会有1.X的upgrade方案。所以如果现在新开始的项目采用Angular的话,会是一个很尴尬的时机。 同样,如此大的改动似乎也反面印证了1.X并不是那么好。
3.学习成本高
使用Angular需要学习大量的概念,包括但不限于:
○模块
○控制器
○指令
○作用域
○模板
○链式函数
○过滤器
○依赖注入
4.不适合类型开发
(1:内容网站,需要SEO的。(SEO目前也有了prerender解决方案)https://prerender.io
(2:交互频繁的,如游戏之类交互体验网站。
(3,太过于简单的页面。
Angular更适合于CRUD的管理系统开发。
3.常见问题
Angular2相比 Vue有什么优势?
4.解决方案
Angular2相对于Vue的优势在Vue2.0之后已经削弱很多了。比如SSR(Vue2已经原生支持)和全栈式框架 (官方推荐Vuex+Vue-Router),native端也有阿里巴巴的weex。但是Angular2在API设计的完整度和覆盖度上还是Vue所不能及的,主要有这么几点:
1.Angular2原生Form支持:
Angular2原生的Form模块功能相当强大。除了双向绑定之类的基本功能,还能通过programaticAPI控制dom元素的表单行为。 也有成型API提供自定义validator。这一点Vue只有v-model和第三方库。对于后台之类的重表单应用,还是Ng2有优势。
2.依赖注入:
无论你喜不喜欢DI,这就是Angular2的强大功能之一。有DI可以在不改变代码结构的情况下完成功能替换。 Vue则需要程序员自己规划代码组织,用来支持共享组件。DI也可以用于类似modulelocalstate的功能。 比如,一个视频播放控件有几个子组件完成,子组件需要分享一个状态。这一点Angular2有原生的serviceinjectionpattern。而Vue则没有官方推荐。 3.对标准向后兼容:
Angular2在一些细节上对标准有更好的支持。比如 listdiffer算法中 Angular2可以支持实现了Symbol.iterator的对象, 而Vue只能支持Array。对Observable和Promise,Angular2在应用的各个地方, 甚至模板级别都有支持(asyncpipe)。而Vue需要vue-rx等第三方库支持。Angular2的组件有shadowdom的实现可以选择,而Vue目前还没有。
4.测试:
Angular2一开始就设计好了如何对组件进行测试,而Vue组件虽然也很好写测试,但是没有官方推荐的唯一标准。 除此以外,Angular2还有一些小功能比如检验模板的类型安全,不过AoT本身似乎还没有稳定,所以不能算优势。对TS的支持也是Angular好, 当然前提是你喜欢TS。总体而言,就是Angular框架的全面性是难以撼动的。
5.编码实战
6.扩展思考
7.参考文献
参考一:参考链接
参考二:知乎
8.更多讨论
【1】Angular1怎么操作DOM元素?
解答:angular11. 操作DOM元素太过于麻烦,还需要封装在自定义指令里面。
【2】angular自带的JQlitegai怎么使用?
解答:它是jQuery的轻量级版本,用法跟jQuery基本一样。
【3】angular2好用还是angular1好用?
解答:作为升级版,肯定功能得到了一定的优化,angular2肯定是强大一些。
鸣谢
感谢大家观看
BY:聂义中
今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~