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