当前位置:首页 > VUE

vue实现mvvm思路

2026-01-18 22:12:20VUE

Vue 实现 MVVM 的思路

Vue 的 MVVM(Model-View-ViewModel)实现主要依赖于数据绑定和响应式系统。以下是其核心实现思路:

数据劫持与响应式

Vue 使用 Object.definePropertyProxy(Vue 3)劫持数据对象的属性,在属性被访问或修改时触发 getter 和 setter。通过依赖收集(Dep)和观察者(Watcher)机制,实现数据的响应式更新。

// 简化版数据劫持示例
function defineReactive(obj, key, val) {
  const dep = new Dep();
  Object.defineProperty(obj, key, {
    get() {
      if (Dep.target) dep.addSub(Dep.target);
      return val;
    },
    set(newVal) {
      if (newVal === val) return;
      val = newVal;
      dep.notify(); // 通知所有 Watcher 更新
    }
  });
}

模板编译

Vue 将模板解析为 AST(抽象语法树),并生成渲染函数。通过指令解析(如 v-modelv-for)和数据绑定,将模板中的动态部分与数据关联起来。

// 简化的模板编译示例
function compile(template) {
  const ast = parse(template); // 解析为 AST
  const code = generate(ast);  // 生成渲染函数代码
  return new Function(`with(this){return ${code}}`);
}

虚拟 DOM 与 Diff 算法

Vue 通过虚拟 DOM 优化渲染性能。数据变化时,生成新的虚拟 DOM,并通过 Diff 算法比对差异,最终高效更新真实 DOM。

// 简化的虚拟 DOM 示例
function createVNode(tag, data, children) {
  return { tag, data, children };
}

function patch(oldVNode, newVNode) {
  // Diff 算法实现
  if (oldVNode.tag !== newVNode.tag) {
    // 替换节点
  } else {
    // 更新属性或子节点
  }
}

双向数据绑定

v-model 是语法糖,本质是 :value@input 的组合。通过监听输入事件更新数据,再触发响应式系统更新视图。

// 简化的 v-model 实现
function bindModel(el, vm, exp) {
  el.addEventListener('input', (e) => {
    vm[exp] = e.target.value; // 数据更新
  });
  new Watcher(vm, exp, (value) => {
    el.value = value; // 视图更新
  });
}

依赖收集与派发更新

  • Dep:管理依赖的容器,每个响应式属性对应一个 Dep。
  • Watcher:观察者,在数据变化时执行回调(如更新视图)。
class Dep {
  constructor() {
    this.subs = [];
  }
  addSub(sub) { this.subs.push(sub); }
  notify() { this.subs.forEach(sub => sub.update()); }
}

class Watcher {
  constructor(vm, exp, cb) {
    this.vm = vm;
    this.exp = exp;
    this.cb = cb;
    Dep.target = this;
    this.value = vm[exp]; // 触发 getter,收集依赖
    Dep.target = null;
  }
  update() {
    const newValue = this.vm[this.exp];
    if (newValue !== this.value) {
      this.cb(newValue);
      this.value = newValue;
    }
  }
}

总结

Vue 的 MVVM 实现核心包括:

vue实现mvvm思路

  • 数据劫持实现响应式。
  • 模板编译生成渲染函数。
  • 虚拟 DOM 优化渲染性能。
  • 依赖收集与派发更新机制。
  • 双向绑定语法糖简化开发。

标签: 思路vue
分享给朋友:

相关文章

vue实现弹窗

vue实现弹窗

Vue 实现弹窗的常见方法 使用组件化方式封装弹窗 创建一个独立的弹窗组件(如 Modal.vue),通过 v-if 或 v-show 控制显示隐藏: <template> <…

vue 实现grid

vue 实现grid

在Vue中实现Grid布局可以通过多种方式完成,以下是几种常见的方法: 使用CSS Grid布局 CSS Grid是一种强大的布局系统,可以直接在Vue组件的样式中使用。以下是一个简单的示例:…

vue如何实现

vue如何实现

Vue 实现方法 在 Vue 中实现功能通常涉及组件化开发、状态管理和响应式数据绑定。以下是几种常见的实现方式: 组件化开发 使用 Vue 的单文件组件(.vue 文件)结构,将 UI 拆分为可复用…

vue实现验证

vue实现验证

Vue 表单验证实现方法 在Vue中实现表单验证可以通过多种方式完成,以下是常见的几种方法: 使用Vuelidate库 Vuelidate是一个轻量级的Vue表单验证库,安装后可以通过简单的配置实现…

vue 实现vshow

vue 实现vshow

Vue 实现 v-show 在 Vue 中,v-show 是一个常用的指令,用于根据条件控制元素的显示或隐藏。与 v-if 不同,v-show 不会移除 DOM 元素,而是通过 CSS 的 displ…

实现vue message

实现vue message

实现 Vue 消息提示组件 创建 Message 组件 在 src/components 目录下创建 Message.vue 文件,内容如下: <template> <tran…