AngularJS 是一个功能齐全的框架,支持 Model-View-Controller 编程结构,非常适合构建动态的单页网络应用程序。
谷歌在2009年开发出了 AngularJS 并对其提供支持,AngularJS 包含一个基于标准 JavaScript 和 HTML 的 JS 代码库。AngularJS 设计的最初目的是作为一个使设计者能够与后端和前端进行交互的工具。
以下是 AngularJS 的部分最好的功能:
为了构建客户端Web应用程序,AngularJS 将原始 MVC 软件设计模式背后的基本原理结合在一起。然而,AngularJS 没有实现传统意义上的 MVC,而是实现了 MVVM 即 Model-View-ViewModel 模式。
AngularJS 带有内置的依赖注入子系统功能,这使得应用程序易于开发和测试。依赖注入允许开发者通过请求来获得依赖关系,而不是搜索依赖关系。这对开发人员非常有帮助。
在 AngularJS 中,可以单独对控制器和指令进行单元测试。AngularJS 允许开发人员进行端到端和单元测试运行器设置,这意味着也可以从用户角度进行测试。
AngularJS 的一个有趣功能是,框架中编写的应用程序在多个浏览器都能运行良好。AngularJS 可以自动处理每个浏览器所需的代码。
AngularJS 的指令(用于渲染指令的DOM模板) 可用于创建自定义的 HTML 标记。这些是 DOM 元素上的标记,因为开发者可以扩展指令词汇表并制作自己的指令,或将它们转换为可重用组件。
由于 AngularJS 主要用于制作单页应用程序,因此必须利用 Deep Linking 功能才能在同一页面上加载子模板。Deep Linking 的目的是为了查看位置 URL 并安排它映射到页面的当前状态。
Deep Linking 功能通过查看页面状态并将用户带到特定内容,而不是从主页中遍历应用程序来设置 URL。Deep Linking 允许所有主要搜索引擎,可以轻松的搜索网络应用程序。
作为一个跨平台的,高度进步的框架,Vue 成为了许多需要创建单页应用程序的开发人员的首选。在用于开发 Web 应用程序的典型 MVC 体系结构中,Vue 充当了 View,这意味着它可以让开发者看到数据的显示部分。除了上面提到的基本功能之外,Vue 还有许多其它优秀功能。
我们来看看这些:
如果你一直在使用其它框架,那么你可以轻松使用 Vue,因为 Vue 的核心库专注于 View 层,你可以轻松地将其与第三方库进行整合并与现有项目一起使用。
由于 Vue 主要关注于 ViewModel 或双向数据绑定,因此 Vue 很轻便。Vue 也具有十分基础的文档。Vue 用做 View 层,意味着开发者可以将它用作页面中的亮点功能,比起全面的 SPA,Vue 提供了更好的选择。
熟悉 HTML 的开发人员会发现 Vue 的学习曲线很低,同时对于经验较少的开发人员和初学者来说,也能够快速地学习和理解 Vue。
Vue 提供了 v-model 指令(用于更新用户输入事件的数据),使得在表单输入和结构元素上实现双向绑定变得很容易。它可以选择正确的方式来更新输入类型相关的元素。
由于 Vue 是基于 Snabbdom 的轻量级虚拟 DOM 实现,因此 Vue 的性能有些许的提升。这是虚拟 DOM 的主要新功能之一,开发者可以直接进行更新。当你需要在实际的 DOM 中进行更改时,只需执行一次这样的更新功能。
Vue 允许开发者直接将渲染的 DOM 绑定到底层的Vue实例数据上。这是一个很有用的功能,因为它可以让开发者扩展基本的 HTML 元素,来保存可复用的代码。
在学习曲线方面,Vue.js 的学习和理解相对简单,而 AngularJS 则需要时间去习惯。开发人员认为这两个框架对于项目来说都很棒,但开发者中的大多数人更喜欢使用 Vue,因为当将 Vuex 添加到项目中时,Vue 更加简单并且可以很好地扩展 。
尽管 Vue 和 Angular 的一些语法类似,比如 API 和设计(这是因为 Vue 实际上是从 Angular 的早期开发阶段中获得启发的),但 Vue 一直致力于在一些对于 Angular 来说很困难的方面提升自己 。开发者可以在几个小时内用 Vue.js 构建一个特别的应用程序,但是这对 Angular 来说是不可能的。
因为Vue编写的目的,使得其学习曲线更简单。
Angular 是独立的,这意味着你的应用程序应该有一定的构造方式。Vue 则更加宽泛,Vue 为创建应用程序提供了模块化,灵活的解决方案。
很多时候,Vue 被认为是一个库而不是框架。默认情况下,Vue 不包含路由器,HTTP 请求服务等。开发者必须安装所需的“插件”。Vue 非常灵活并且可以与大多数开发者想要使用的库兼容。
不过,也有开发人员更喜欢 Angular,因为 Angular 为其应用程序的整体结构提供了支持。这有助于节省编码时间。
因为Vue的结构由使用者自己决定,所以其更加灵活。
Vue 通过最少量的组件重新渲染,可以将模板预编译为纯 JavaScript。这个虚拟 DOM 允许进行大量的优化,这是 Vue 和 Angular 之间的主要区别。Vue 允许使用更简单的编程模型,而 Angular 则以跨浏览器兼容的方式操作 DOM。
Vue使用虚拟DOM所以更加轻量化。
虽然 Angular 和 Vue 都提供了很高的性能,但由于 Vue 的虚拟 DOM 实现的重量较轻,所以可以说 Vue 的速度/性能略微领先。
更简单的编程模型使 Vue 能够提供更好的性能。Vue 可以在没有构建系统的情况下使用,因为开发者可以将其包含在 HTML 文件中。这使得 Vue 易于使用,从而提高了性能。
Angular 可能会很慢的原因是它使用脏数据检查,这意味着 Angularmonitors 会持续查看变量是否有变化。
Vue 的速度/性能略微领先
Angular采用脏值检查:angular.js 是通过脏值检测的方式比对数据是否有变更,来决定是否更新视图,最简单的方式就是通过 setInterval() 定时轮询检测数据变动,然而angular只有在指定的事件触发时进入脏值检测。1
Vue采用数据劫持: vue.js 是采用数据劫持结合发布者-订阅者模式的方式,通过Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时发布消息给订阅者,触发相应的监听回调。2
Angular 的双向绑定相对复杂。
相比较来说,Vue在学习曲线和灵活性上都更具优势,而Angular在凭借TypeScript3 本身比 JavaScript 更加工程化的优势,使得代码的可读性和可重构性都更好。不要求敏捷开发的大型项目使用Angular更具优势。
AngularJs 双向绑定原理(数据绑定机制) ↩︎
剖析Vue原理&实现双向绑定MVVM ↩︎
TypeScript 是 JavaScript 的一个超集,
支持 ECMAScript 6 标准。
TypeScript 由微软开发的自由和开源的编程语言。
TypeScript 设计目标是开发大型应用,它可以编译成纯JavaScript,编译出来的 JavaScript 可以运行在任何浏览器上。
TypeScript 是一种给 JavaScript 添加特性的语言扩展。 ↩︎