微信号:FrontDev

介绍:分享 Web 前端相关的技术文章、工具资源、精选课程、热点资讯

JS 框架比较:AngularJS vs ReactJS vs EmberJS

2016-12-21 20:33 前端大全

(点击上方公众号,可快速关注)


英文:Nataliya Orlovska 

译文:码农网 – 小峰

链接:www.codeceo.com/article/angularjs-reactjs-emberjs.html


选择最适合项目需求的JavaScript框架,可以提高你发布有竞争力的web app的能力。

最后,你对基于JavaScript的app或网站找到了一条奇妙的思路。选择正确的框架可能对你项目的成功有着相当大的影响。它可以影响你按时完成项目并在将来维护代码的能力。JavaScript框架,如Angular.js,Ember.js或React.js,给你的代码带来结构,并保持其有序化,从而使您你的app更灵活,更具可扩展性,并更容易开发。

Javascript场景的易变性

Web开发的变化发生的很快。几乎每个月都会引入一个新的JavaScript框架,并且现有的框架经常被更新。由于这些框架是开放源代码的,因此世界各地的大型社区也都可以不断地使之丰满起来。因此,了解每个框架的优点和它们之间的区别并不是一件容易的事情。

深入Angular vs React vs Ember

许多开发人员因为JavaScript框架的种类繁多而感到眼花缭乱——框架外观和功能非常不同。

让我们来比较一下三个最流行和广泛使用的JavaScript框架的优势:AngularJS,ReactJS和EmberJS。


AngularJS: 框架领域的冠军

Angular.js是一个开源的Web应用程序框架,具有由Google提供的Model-View-Controller(MVC)架构(Angular 1)和Model-View-ViewModel(MVVM)架构(Angular 2)。它是上面提到的三个框架中最古老的。因此,它拥有最大的社区。 Angular.js通过使用指令扩展HTML的功能来解决开发SPA(单页应用程序)的问题。此框架强调让你的app快速完成和运行。

Angularjs的优缺点

优点:

  • 创建自定义的文档对象模型(DOM)元素。

  • 简单的UI设计和更改。

  • 在HTML文档中创建输入字段时,将为每个已渲染字段创建单独的数据绑定。Angular倾向于在重新渲染之前检查页面上的每个单个绑定字段的任何变化。

  • 依赖注入。

  • 简单路由。

  • 易于测试的代码。

  • 此框架利于HTML语法的扩展,并通过指令创建可重用的组件。

  • 强大的模板构建解决方案。在HTML属性中使用绑定表达式来驱动模板功能。Angular的模板引擎对DOM有着深入的理解,且其结构良好的模板减少了创建结果页面所需的代码总量。

  • 数据建模限于小数据模型的使用,以使代码简单易于测试。

  • 在渲染静态列表时速度快。

  • 伟大的代码重用(Angular库)。

缺点:

  • 指令API的复杂性。

  • 对于具有许多交互元素的页面,Angular变得缓慢。

  • 原始设计往往很慢。

  • 由于许多DOM元素,性能方面有问题。

  • 复杂的第三方集成。

  • 陡峭的学习曲线。

  • 范围很容易使用,但很难调试。

  • 路由受限。

注意。Angular 2的功能与上述不同。Angular 2不是从Angular 1重新设计的,它被完全重写了。两个版本的框架之间的巨大变化在开发人员之间引起了相当大的争议。

ReactJS: 在块上的新生儿

ReactJS是一个开源的JavaScript库,用于构建高性能的用户界面,专注于由Facebook引入和提供的惊人的渲染性能。React专注于模型视图控制器(Model View Controller)架构中的“V”。在React第一次发布后,它迅速吸引了大量用户。它是为了解决与其他JavaScript框架的常见问题——大数据集的高效渲染而创建的。

Reactjs的优缺点

优点:

  • 简单的界面设计和学习API。

  • 比其他JavaScript框架显着的性能提升。

  • 更快的更新。React使用最新的数据创建新的虚拟DOM和修补机制,并高效地将其与以前的版本进行比较,创建一个最小的更新部分列表,使其与真正的DOM同步,而不是每次更改时重渲染整个网站。

  • 服务器端渲染允许创建同构/通用web app。

  • 容易导入组件,尽管具有很少的依赖性。

  • 良好的代码重用。

  • 非常适合JavaScript调试

  • 完全有可能用React增强Angular以增强麻烦的组件的性能。

  • 完全基于组件的架构。

  • JSX,一种JavaScript扩展语法,允许引用HTML并使用HTML标记语法来渲染子组件。

  • React本地库。

缺点:

  • 不是一个完整的框架,而是一个库。

  • 非常复杂的视图层。

  • Flux架构不同于开发人员习惯的范例。

  • 很多人不喜欢JSX。

  • 陡峭的学习曲线。

  • 将React集成到传统的MVC框架,如Rails中需要一些配置。

EmberJS: 所有的繁重工作

EmberJS是一个用于创建单页面客户端Web应用程序的开源JavaScript应用程序框架,使用Model-View-Controller (MVC)模式。此框架提供通用数据绑定和URL驱动方法,用于构建不同的应用程序,重点放在可扩展性。

Ember在2007年最初被发布时,叫做SproutCore。2011年,它被Facebook收购,并重命名为Ember。它结合了本地框架,例如Apple的Cocoa的经过验证的概念以及轻量级的敏感性。

Embersjs的优缺点

优点:

  • 约定优于配置。Ember.js不是为应用程序中的各种路由提供详细的配置,而是喜欢遵循命名约定并自动生成结果代码,仅在不遵守约定的情况下指定配置。

  • 客户端渲染和结构到可扩展的web应用程序超出视图层。

  • URL支持。

  • Ember的对象模型利于键值观察。

  • 嵌套的UI。

  • 最小化DOM。

  • 适用于大型应用程序生态系统。

  • 强数据层与Java集成良好。

  • 完全成型的模板机制(Handlebars模板引擎构建在流行的Mustache 模板引擎上)减少了编写的代码总量。它对DOM一无所知,而是依赖于直接的文本操作,动态地构建HTML文档。

  • 使用观察者来改变值,这将导致仅渲染更改的值。

  • 通过使用附件避免“脏检查”。

  • 更快的启动时间和固有的稳定性。

  • 性能焦点。

  • 友好的文档和API。

缺点:

  • Ember.js缺少控制器级别的组件重用。

  • 有很多过时的不再工作的内容和示例。

  • 陡峭的学习曲线。

  • Handlebars使用许多<script>标记来污染DOM,用作标记以使模板保持更新到模型。

  • 当走出其典型用途时会很麻烦。

  • Ember的对象模型实现膨胀Ember的整体大小并在调试时调用堆栈。

  • 最有见地和最重的框架。

  • 对于小项目而言过大。

  • 测试用例似乎模糊/不完整。

比较Angularjs Vs Reactjs Vs Emberjs功能



定义你的需求并使选定的框架发挥最大的作用

确定哪个框架适合你,只需要评估应用程序的需求以及每个框架的优势即可。这需要深入了解所考虑的每个框架的优点和缺点,以及它们如何在不同用例下竞争。所有框架都有很多共同点:开源,在许可证下发布,并创建具有MVC设计模式的SPA。它们都有视图,事件,数据模块和路由。然而,不同的JavaScript框架更适合不同类型的应用程序。

如果你正在决策创建一个web app,对于长期支持和活跃的社区,Angular,React和Ember是最安全的。此外,目前Angular是这三个中最受欢迎的。你可以一站式使用。它是大型企业的首选框架。Ember是那些寻求全工具包含框架方法的人的最佳解决方案。Ember可以帮助你做出许多决策,所以你不必花时间研究和胶合库。由于Ember需要很长时间学习,所以它适合长期项目。React是上面提名的三个框架中最轻量级的。它的伟大在于一件事:渲染UI组件。许多人甚至将其与前面提到的框架进行配对。如果你需要逐渐现代化现有的代码库,那么这是一个合适的选择。

正如你看到的,没有明确的胜利者。有的框架比其他框架更适合特定的项目。当然,你也可以从几个不同的角度检查你的项目,包括成熟度,大小,依赖性,互操作性,功能等,并联系专业的前端web开发公司来构建完美的网站架构和网站设计,以便于更好地满足你的业务。


觉得本文对你有帮助?请分享给更多人

关注「前端大全」,提升前端技能

 
前端大全 更多文章 程序员学习新技术的10个建议 12 款 JavaScript 代码测试必备工具 vue 2.0 开发实践总结之入门篇 趣图:调试 CSS 的感觉就是这样的 JavaScript 有个 Unicode 的天坑
猜您喜欢 技术大牛第一式 - 重构 Uber是如何基于Go语言构建高QPS服务的? 【重磅】微信开源PhxSQL:高可用、强一致的MySQL集群 为什么国外程序员爱用苹果 Mac 电脑? 了不起!梅格剧透的IoT世界竟有这样的神奇画风……