当前位置:首页 > VUE

vue响应式实现机制

2026-02-23 18:33:04VUE

Vue 响应式实现机制

Vue 的响应式系统通过数据劫持和依赖收集实现,核心基于 Object.defineProperty(Vue 2)或 Proxy(Vue 3)。以下是具体实现机制:

数据劫持

Vue 2 使用 Object.defineProperty 劫持对象的属性访问和修改。通过定义 gettersetter,在属性被访问或修改时触发依赖更新。

vue响应式实现机制

// Vue 2 数据劫持简化示例
function defineReactive(obj, key, val) {
  Object.defineProperty(obj, key, {
    get() {
      console.log('get', key);
      return val;
    },
    set(newVal) {
      if (newVal !== val) {
        console.log('set', key);
        val = newVal;
      }
    }
  });
}

Vue 3 改用 Proxy 代理整个对象,能直接监听对象增删和数组变化,无需递归遍历属性。

// Vue 3 Proxy 示例
const reactive = (target) => {
  return new Proxy(target, {
    get(target, key, receiver) {
      console.log('get', key);
      return Reflect.get(target, key, receiver);
    },
    set(target, key, value, receiver) {
      console.log('set', key);
      return Reflect.set(target, key, value, receiver);
    }
  });
};

依赖收集

每个响应式数据关联一个 Dep 实例(依赖管理器),在 getter 中收集当前正在执行的 Watcher(依赖),在 setter 中通知所有 Watcher 更新。

vue响应式实现机制

class Dep {
  constructor() {
    this.subscribers = new Set();
  }
  depend() {
    if (activeWatcher) this.subscribers.add(activeWatcher);
  }
  notify() {
    this.subscribers.forEach(watcher => watcher.update());
  }
}

let activeWatcher = null;
class Watcher {
  constructor(updateFn) {
    this.updateFn = updateFn;
    this.update();
  }
  update() {
    activeWatcher = this;
    this.updateFn();
    activeWatcher = null;
  }
}

虚拟 DOM 与批量更新

数据变化触发 Watcher 更新后,Vue 通过异步队列(nextTick)批量处理 DOM 更新,避免重复渲染。虚拟 DOM 差异比对(diff 算法)最小化真实 DOM 操作。

数组响应式处理

Vue 2 通过重写数组的 pushpop 等方法实现响应式,内部调用 ob.dep.notify() 通知更新。Vue 3 的 Proxy 可直接监听数组索引变化。

// Vue 2 数组劫持示例
const arrayProto = Array.prototype;
const arrayMethods = Object.create(arrayProto);
['push', 'pop'].forEach(method => {
  const original = arrayProto[method];
  arrayMethods[method] = function(...args) {
    const result = original.apply(this, args);
    this.__ob__.dep.notify();
    return result;
  };
});

总结

  • Vue 2:基于 Object.defineProperty + Dep/Watcher,需递归遍历对象且对数组特殊处理。
  • Vue 3:基于 Proxy + effect(类似 Watcher),支持原生对象和数组操作,性能更优。

标签: 机制vue
分享给朋友:

相关文章

vue设计与实现目录

vue设计与实现目录

以下是《Vue设计与实现》一书的典型目录结构(根据常见技术书籍及Vue核心内容整理): 响应式系统 响应式数据的基本原理 依赖收集与触发更新 实现简易响应式系统 Proxy与Refle…

vue实现div

vue实现div

Vue 实现 DIV 元素的方法 在 Vue 中实现 DIV 元素可以通过多种方式,以下是几种常见的实现方法: 使用模板语法 在 Vue 的模板中直接使用 HTML 的 <div> 标…

vue怎么实现

vue怎么实现

Vue 实现方法 Vue 是一个流行的前端框架,用于构建用户界面。以下是几种常见的实现方法: 数据绑定 使用 v-model 指令实现双向数据绑定,适用于表单输入元素。 <input v-m…

vue 实现滚动

vue 实现滚动

实现滚动的基本方法 在Vue中实现滚动效果可以通过多种方式完成,包括使用原生JavaScript、CSS或第三方库。以下是一些常见的方法: 使用window.scrollTo方法实现页面滚动 可以通…

vue实现 toast

vue实现 toast

Vue 实现 Toast 组件 在 Vue 中实现 Toast 组件可以通过多种方式完成,以下是几种常见的方法: 使用全局组件和事件总线 创建一个全局的 Toast 组件,并通过事件总线或 Vue…

vue实现oauth

vue实现oauth

Vue 实现 OAuth 的步骤 安装必要的依赖 确保项目中安装了 axios 和 vue-router。OAuth 通常需要发送 HTTP 请求和处理路由跳转。 npm install axios…