您的当前位置:首页正文

面试题:react和vue的区别分析

2020-11-27 来源:意榕旅游网

看起来MVC的概念很舒服,框架的很规范,但是代码量多了之后,就会显得整个项目很臃肿,一点都不灵活。

作者有幸维护过一个称为“屎山”的angular1.x项目,因为经过上百次(大概有)的需求迭代后,每个controller的代码超过2000行,每次修bug和写新需求,都需要维护很多方方面面的东西。

然后我们来了解下MVVM。

<input v-model="ball.basketball" />
let vm = new Vue({
 data: {
 ball: {
 baskertball: '蔡徐坤就是我'
 }
 }
})
  • M:Model 模型
  • V:View 视图
  • VM: ViewModel 视图模型
  • 其实看代码就理解了,vm其实就是vue对象。它的功能就是绑定到view上,Model里的篮球不管更新,还是做其他操作,都会通过vm来通知派发至view。

    这样做的好处呢,第一点,一个业务逻辑你就不用写很多遍。类似一个shopcart的功能,你把它的封装成一个组件(ViewModel)在很多地方都可以直接引入调用。

    ps:vue和React两者的区别和共同点

    两者的本质区别

    1.vue本质是MVVM框架,是由MVC发展而来。

    2.React本质是前端组件化框架,是由后端组件化发展而来。

    模板的区别

    1.vue使用模板--(最初由angular提出)

    <div>
      <h1 v-if="ok">Yes</h1>
      <h1 v-else>No</h1>
    </div>

    2.React使用JSX模板,现在已经趋向标准化,完全可以独立出来使用。

    <div>
    {ok?<h1>Yes</h1>:<h1>No</h1>}
    </div>

    从学习成本来说:JSX模板更简单,只需要知道{ }里是js语法,vue模板v-if,v-else指令需要学习。
    从模板逻辑分离角度考虑:JSX模板和JS逻辑混在一起,没有分开,容易造成混乱。

    3.组件化的区别

    React本身就是组件化,没有组件化就不是React
    vue也支持组件化,不过是在MVVM上的扩展

    4.两者的共同点

    都支持组件化

    都是数据驱动视图

    总结

    以上所述是小编给大家介绍的面试题:react和vue的区别分析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

    显示全文