VUE 响应式原理

vue2 响应式原理(一)

简要介绍

vue2响应式主要通过 object.defineProperty 对响应式对象的每个属性进行监听 在get时收集依赖,在set设置属性值时触发所有依赖更新

下面带大家实现一下简单的响应式,主要下述几个关键类和函数:

  • observe(obj) 负责将 obj 设为响应式对象
  • defineReactive(obj, key) 将obj的每个属性进行劫持,get时收集依赖,set时触发更新
  • Dep类 保存对象单项属性的依赖
  • Watcher类 依赖本身

observe的实现

js 复制代码
function observe(obj) {
  // 判断下obj为对象且不为null,不然直接返回
  if(typeof obj !== 'object' || obj == null) return obj;
  // 遍历每个属性都设置为响应式
  Object.keys(obj).forEach((key) => {
    defineReactive(obj, key);
  })
}

defineReactive 的实现

js 复制代码
function defineReactive(obj, key) {
  // 递归深层遍历属性设置响应式
  if(typeof obj[key] !== 'object' || obj[key] == null) observe(obj[key]);
  // Dep类的作用是,收集保存每个属性的依赖
  const dep = new Dep();
  Object.defineProperty(obj, key, {
    get() {
      // 收集依赖,后面详细解释Dep.target的作用
      Dep.target && dep.addSub(Dep.target)
      return obj[key];
    },
    set(newValue) {
      // dep.subs保存的所有依赖,每个sub都是一个Watcher对象
      if(newValue !== obj[key]) dep.notify();
    }
  })
}

Dep类的实现

js 复制代码
Class Dep {
  constructor() {
    // 存放依赖列表
    this.subs = [];
  }
  addSub(sub) {
    this.subs.push(sub)
  }
  notify() {
    this.subs.forEach(sub => sub.upload())
  }
}

Watcher的实现

js 复制代码
Class Watcher {
  constructor(obj, key, callBack) {
    this.obj = obj;
    this.callBack = callBack;
    Dep.target = this;
    // 触发get收集依赖
    this.value = obj[key];
    Dep.target = null;
  }
  upload() {
    if(this.value !== this.obj[key]) {
      this.value = this.obj[key];
      this.callBack();
    }
  }
}

大佬们如果有哪里漏掉了还请多多指点~

相关推荐
一只小阿乐1 分钟前
前端vue3 web端中实现拖拽功能实现列表排序
前端·vue.js·elementui·vue3·前端拖拽
AAA阿giao6 分钟前
从“操纵绳子“到“指挥木偶“:Vue3 Composition API 如何彻底改变前端开发范式
开发语言·前端·javascript·vue.js·前端框架·vue3·compositionapi
TextIn智能文档云平台12 分钟前
图片转文字后怎么输入大模型处理
前端·人工智能·python
专注前端30年14 分钟前
在日常开发项目中Vue与React应该如何选择?
前端·vue.js·react.js
文刀竹肃28 分钟前
DVWA -XSS(DOM)-通关教程-完结
前端·安全·网络安全·xss
lifejump32 分钟前
Pikachu | XSS
前端·xss
进击的野人36 分钟前
Vue 组件与原型链:VueComponent 与 Vue 的关系解析
前端·vue.js·面试
馬致远44 分钟前
Vue todoList案例 优化之本地存储
前端·javascript·vue.js
请叫我聪明鸭44 分钟前
CSS实现单行、多行文本超长显示 / 不超长隐藏、悬浮窗超长展示/不超长隐藏、悬浮窗手动控制样式
前端·javascript·css
blackorbird1 小时前
苹果修复了两个在定向攻击中被利用的Webkit漏洞,其中一个与谷歌ANGLE漏洞同源
前端·webkit