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 和 Vue

    ++本文系慕课网学习笔记++ 如何理解 MVVM 如何实现 MVVM 是否解读过 vue 的源码(vue 中的 x...

  • MVVM学习笔记

    MVVM是什么 MVVM是Model-View-ViewModel的简写,本质上是MVC的改进版。ViewMode...

  • MVVM 学习笔记

    参考资料:http://www.jianshu.com/p/a15d6e68d93f MVVM 是从 MVP 的进...

  • 值得学习的技术文章(持续添加)

    1. MVVM 学习资料 MVVM奇葩说 面向协议的 MVVM 架构介绍 MVVM With ReactiveCo...

  • MVVM之DataBinding学习笔记

    [TOC] 前言 ...想了半分钟,好像并没有啥需要特别声明的,能翻到这篇文章的人,相信也早已了解了DataBin...

  • ReactiveCocoa & MVVM学习笔记

    网上关于RAC和MVVM的资料非常多,我写这篇主要是因为初学RAC,为自己记个学习笔记。 1. RAC是什么? (...

  • 3月份学习计划

    1.把疯狂kotlin看完,并做好相应的笔记 2.看完Android开发艺术探索 3.学习搭建MVVM框架

  • Vue学习笔记目录

    本文为转载,原文:Vue学习笔记目录 Vue介绍 Vue.js是当下很火的一个JavaScript MVVM库,它...

  • ReactiveCocoa笔记

    最近在做MVVM项目改造,绕不开reactivecocoa(rac),学习过程中做的一些简单的笔记,用于快速上手,...

  • Vue原理研究之双向数据绑定

    前言 本篇文章主要研究Vue的双向数据绑定的学习笔记。具体细节请参考《剖析Vue原理&实现双向绑定MVVM》。 原...

网友评论

    本文标题:MVVM学习笔记

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