MVVM学习笔记

作者: lzb30 | 来源:发表于2018-04-08 21:32 被阅读0次

    MVVM是什么

    MVVM是Model-View-ViewModel的简写,本质上是MVC的改进版。
    ViewModel相当于Model和View的桥梁,它的作用有两个:一个是让View通过事件绑定更新Model,一个是让Model通过数据绑定更新View。

    为什么使用MVVM

    这就要讲到它和jQuery的区别:
    jquery是通过DOM操作来更新视图,而用MVVM框架,我们只需要关注Model的变化,MVVM框架会自动更新DOM,不需要我们频繁操作DOM。

    MVVM的三大要素

    1、模板

    模板本质上是字符串,与HTML类似,但有很大区别,区别在于模板上有逻辑(如v-if, v-for),最后要渲染成HTML。
    那模板如何实现,需要把模板转换成一段js代码,然后通过js来渲染成HTML。

    2、响应式

    响应式解决的是对数据的变化进行监听。这里要用到Object.defineProperty函数,在这个函数有get和set方法,可以对数据的变化进行监听。

    3、页面渲染

    页面渲染要解决两个问题:
    一个是把模板转换成vnode,另一个是把vnode重新渲染成HTML。
    这里纪要讲到虚拟DOM的概念。
    虚拟DOM顾名思义就是虚拟的DOM对象,这个对象包含了跟DOM相关的大部分信息,比如标签,属性和子元素。
    为什么要用到虚拟DOM?
    因为传统的数据变化需要重新渲染整个DOM,我们知道DOM的操作是昂贵的,而虚拟DOM则可以做到最小程度的修改DOM。

    MVVM的实现流程

    1、首次渲染、显示页面并绑定依赖

    初次渲染,执行updateComponent,调用render()
    执行render函数,会访问到Model的数据
    会被响应式的get方法监听到
    用vdom的patch方法把vnode渲染成DOM,初次渲染完成。

    为什么监听get

    因为data中有很多属性,有些会用到,有些用不到
    被用到的会走get,不被用到的不会走到get
    避免不必要的渲染

    2、监听data属性变化

    修改属性,被响应式的set监听到,重新渲染DOM

    相关文章

      网友评论

        本文标题:MVVM学习笔记

        本文链接:https://www.haomeiwen.com/subject/uswmhftx.html