你们好呀,清明节这两天有没有出门踏青扫墓呢!!!javascript
言归正传,这是做者面试系列的第二篇文章!!!!!!!vue
三大框架之二,你们应该都不会陌生,都有学习过或者开发中使用。java
可是他们到底有啥区别呢?这个就是咱们这篇文章所需探讨并学习的。react
开始!面试
首先,来讲明下这些字母表明的含义数组
首先说下MVC,你们确定也知道三大框架中的另一个(anuglar)。mvc
若是你写过angular那就确定能很清楚的了解这个含义,看以下代码:框架
<input ng-model="ball.basketball" />
.contronller('BallController', ($scope) => {
const ball = {
basketball: '我是蔡徐坤'
}
$scope.ball = ball
})
复制代码
input标签很好理解,就是MVC中的V(view)视图。dom
controller顾名思义,就是MVC中的C(controller)控制器。mvvm
ball的话就是MVC中的M(model)模型。
MVC的概念很简单,你要展现一个篮球的页面。
- 设置一个篮球的模型放在那等待使用。
- 写一个你须要展现篮球的视图。
- 使用控制器来让模型和视图交互。
看起来MVC的概念很舒服,框架的很规范,可是代码量多了以后,就会显得整个项目很臃肿,一点都不灵活。
做者有幸维护过一个称为“屎山”的angular1.x项目,由于通过上百次(大概有)的需求迭代后,每一个controller的代码超过2000行,每次修bug和写新需求,都须要维护不少方方面面的东西。
<input v-model="ball.basketball" />
let vm = new Vue({
data: {
ball: {
baskertball: '蔡徐坤就是我'
}
}
})
复制代码
其实看代码就理解了,vm其实就是vue对象。它的功能就是绑定到view上,Model里的篮球无论更新,仍是作其余操做,都会经过vm来通知派发至view。
这样作的好处呢,第一点,一个业务逻辑你就不用写不少遍。相似一个shopcart的功能,你把它的封装成一个组件(ViewModel)在不少地方均可以直接引入调用。
写着写着做者就以为跑题了,其实vue和react都是借鉴了mvvm的概念思想,加上工程师本身的想法而出现的两个优秀框架。
他们的区别:
面试系列第一篇: 面试官:你知道Callback Hell(回调地狱)吗?