zoukankan      html  css  js  c++  java
  • vue响应式原理 (响应式并不等于数据双向绑定,千万不要混淆)

    vue实现数据双向绑定主要是:采用数据劫持结合发布者-订阅者模式的方式,通过 Object.defineProperty() 数据劫持,来劫持各个属性的setter,getter,在数据更新时发布消息给订阅者,触发相应监听回调。

    当把一个普通 Javascript 对象传给 Vue 实例来作为它的 data 选项时,Vue 将遍历它的属性,用 Object.defineProperty() 将它们转为 getter/setter。用户看不到 getter/setter,但是在内部它们让 Vue 追踪依赖,在属性被访问和修改时通知变化。

    vue的数据双向绑定 将MVVM作为数据绑定的入口,整合Observer,Compile和Watcher三者,通过Observer来监听自己的model的数据变化,通过Compile来解析编译模板指令(vue中是用来解析 {{}}),

    最终利用watcher搭起observer和Compile之间的通信桥梁,达到数据变化 —>视图更新;视图交互变化(input)—>数据model变更双向绑定效果。

    1、Object.defineProperty()  (Observer 监听model数据变化)

    语法: Object.defineProperty(obj, prop, descriptor)
    obj:要定义的对象
    prop:要定义的对象的属性
    descriptor:要定义或修改的属性描述符。

     

     

    2、订阅-发布者模式 (watcher)

    订阅模式其实就是就是一个队列,我们把需要执行的函数推进一个数组,在需要用的时候依次去执行这个数组中方法

    订阅就是把函数PUSH到数组,

    发布就是便利执行这些函数

     

     3、compile 模板编译

    vue模板编译其实就是把 template 模板编译成浏览器可识别的 HTML 

    具体原理参考博文:https://segmentfault.com/a/1190000012922342

  • 相关阅读:
    hdu 1998 奇数阶魔方(找规律+模拟)
    巧用百度Site App新组件为企业官网打造移动站
    POJ 1276 Cash Machine
    Unity3D中使用MiniJson解析json的例子
    设计模式读书笔记-----单例模式
    android 常用资料
    Objective-C之run loop详解
    icon 图标下载
    揭开Html 标签的面纱,忘不了的html .
    12157
  • 原文地址:https://www.cnblogs.com/xxflz/p/14134080.html
Copyright © 2011-2022 走看看