web前端三⼤主流框架的对⽐
MVX框架模式:MVC+MVP+MVVM
1.MVC:Model(模型)+View(视图)+controller(控制器),主要是基于分层的⽬的,让彼此的职责分开。
View通过Controller来和Model联系,Controller是View和Model的协调者,View和Model不直接联系,基本联系都是单向的。
⽤户User通过控制器Controller来操作模板Model从⽽达到视图View的变化。
2.MVP:是从MVC模式演变⽽来的,都是通过Controller/Presenter负责逻辑的处理+Model提供数据+View负责显⽰。
在MVP中,Presenter完全把View和Model进⾏了分离,主要的程序逻辑在Presenter⾥实现。
并且,Presenter和View是没有直接关联的,是通过定义好的接⼝进⾏交互,从⽽使得在变更View的时候可以保持Presenter不变。MVP模式的框架:Riot,js。
3.MVVM:MVVM是把MVC⾥的Controller和MVP⾥的Presenter改成了ViewModel。Model+View+ViewModel。
View的变化会⾃动更新到Model, Model的变化也会⾃动同步到View上显⽰。
这种⾃动同步是因为ViewModel中的属性实现了Observer,当属性变更时都能触发对应的操作。
Vue.js是什么?
看到了上⾯的框架模式介绍,我们可以知道它是属于MVVM模式的框架。那它有哪些特性呢?
其实Vue.js不是⼀个框架,因为它只聚焦视图层,是⼀个构建数据驱动的Web界⾯的库。
Vue.js通过简单的API(应⽤程序编程接⼝)提供⾼效的数据绑定和灵活的组件系统。
Vue.js的特性如下:
1. 轻量级的框架
2. 双向数据绑定
3. 指令
4. 插件化
Vue.js与其他框架的区别?
1. 与AngularJS的区别
相同点:
都⽀持指令:内置指令和⾃定义指令。
都⽀持过滤器:内置过滤器和⾃定义过滤器。
都⽀持双向数据绑定。
都不⽀持低端浏览器。
不同点:
1.AngularJS的学习成本⾼,⽐如增加了Dependency Injection特性,⽽Vue.js本⾝提供的API都⽐较简单、直观。
2.在性能上,AngularJS依赖对数据做脏检查,所以Watcher越多越慢。
Vue.js使⽤基于依赖追踪的观察并且使⽤异步队列更新。所有的数据都是独⽴触发的。
对于庞⼤的应⽤来说,这个优化差异还是⽐较明显的。
2. 与React的区别web前端的基本框架
相同点:
React采⽤特殊的JSX语法,Vue.js在组件开发中也推崇编写.vue特殊⽂件格式,对⽂件内容都有⼀些约定,两者都需要编译后使⽤。中⼼思想相同:⼀切都是组件,组件实例之间可以嵌套。
都提供合理的钩⼦函数,可以让开发者定制化地去处理需求。
都不内置列数AJAX,Route等功能到核⼼包,⽽是以插件的⽅式加载。
在组件开发中都⽀持mixins的特性。
不同点:
React依赖Virtual DOM,⽽Vue.js使⽤的是DOM模板。React采⽤的Virtual DOM会对渲染出来的结果做脏检查。Vue.js在模板中提供了指令,过滤器等,可以⾮常⽅便,快捷地操作DOM。