博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Vue 响应式实现原理(个人在学习完Vue基础的情况下的理解)
阅读量:6082 次
发布时间:2019-06-20

本文共 1364 字,大约阅读时间需要 4 分钟。

1. Vue 对象

1.1 用户看到的对象

var app = new Vue({    el: '#app' ,     /*     * 用户看到的是这个对象     */    data: {        name: 'chenxuelong' ,         sex: 'male'    }});// 即是console.log(app.data);

1.2 Vue 实际使用的对象

// Vue 实际使用的对象app.$data = {};for (var k in app.data){    copy(k);}// 复制function copy(k){    Object.defineProperty(app.$data , k , {        get: function(){            return app.data[k];        } ,         set: function(value){            app.data[k] = value;                        // 更新相应 dom 的代码        } ,        enumerable: true ,         configurable: true    });}

2. Vue 实现 data 对象代理

for (var k as app.$data){    copy(k);   }function copy(k){    Object.defineProperty(app , k , {        get: function(){            app.$data[k];        } ,         set: function(val){            app.$data[k] = val;        } ,         enumerable: true ,         configurable: true    });}

3. Vue 响应式原理

3.1 前提

Vue 官网说过,限于现代浏览器 JavaScript 限制,Vue 无法监测通过 app.test = 'hello boy' 这种方式添加的属性,所以,他的响应式是建立在实例化 Vue 对象的时候,预定义 data 属性的基础上的。

3.2 原理

// 必须在实例化 Vue 时,预定义好要用到的 data 属性// 否则实现不了响应式var app = new Vue(    el: '#app' ,     // 这个时候,Vue 内部会新建一个 $data 属性    // 具体过程请看步骤 1.2    // 然后实现 data 对象代理,具体过程请看    // 步骤 2    // 通过以上步骤后, data 对象中的数据属性    // 就都被转化为 存取器属性(getter/setter) 了    // Vue 就是通过 getter/setter 来追踪属性变化的    data: {        name: 'chenxuelong' ,         sex: 'male'    });

转载地址:http://yhkwa.baihongyu.com/

你可能感兴趣的文章
css知多少(8)——float上篇
查看>>
NLB网路负载均衡管理器详解
查看>>
水平添加滚动条
查看>>
PHP中”单例模式“实例讲解
查看>>
VS2008查看dll导出函数
查看>>
VM EBS R12迁移,启动APTier . AutoConfig错误
查看>>
atitit.细节决定成败的适合情形与缺点
查看>>
Mysql利用binlog恢复数据
查看>>
我的友情链接
查看>>
用yum安装mariadb
查看>>
一点IT"边缘化"的人的思考
查看>>
WPF 降低.net framework到4.0
查看>>
搭建一个通用的脚手架
查看>>
开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
查看>>
开源磁盘加密软件VeraCrypt教程
查看>>
本地vs云:大数据厮杀的最终幸存者会是谁?
查看>>
阿里云公共镜像、自定义镜像、共享镜像和镜像市场的区别 ...
查看>>
shadowtunnel v1.7 发布:新增上级负载均衡支持独立密码
查看>>
Java线程:什么是线程
查看>>
mysql5.7 创建一个超级管理员
查看>>