当前位置:首页 > 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)机制,实现数据的响应式更新。

vue实现mvvm思路

// 简化版数据劫持示例
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。

vue实现mvvm思路

// 简化的虚拟 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 实现核心包括:

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

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

相关文章

用vue实现滑动输入条

用vue实现滑动输入条

使用 Vue 实现滑动输入条 使用原生 HTML5 input range 实现 在 Vue 模板中直接使用 <input type="range">,通过 v-model 绑定数据:…

vue全选实现

vue全选实现

Vue 全选实现方法 在 Vue 中实现全选功能通常涉及数据绑定和事件处理。以下是几种常见的实现方式: 基础实现方式 <template> <div> <i…

vue实现盖章

vue实现盖章

Vue 实现盖章功能 在Vue中实现盖章功能通常涉及前端UI交互,通过Canvas或SVG绘制印章,并允许用户拖拽或点击放置印章。以下是具体实现方法: 使用Canvas绘制印章 通过HTML5的Ca…

vue实现批量

vue实现批量

Vue 实现批量操作的方法 在 Vue 中实现批量操作通常涉及选择多个项目并执行统一处理,例如批量删除、批量更新等。以下是几种常见实现方式: 表格多选批量操作 使用 el-table 配合复选框实现…

vue 实现列表

vue 实现列表

Vue 实现列表的方法 在 Vue 中实现列表通常使用 v-for 指令,结合数组或对象数据渲染动态列表。以下是几种常见的实现方式: 基础列表渲染 使用 v-for 指令遍历数组,渲染列表项。ite…

vue实现返回

vue实现返回

返回按钮功能实现 在Vue中实现返回功能通常有两种方式:使用浏览器历史记录的history.back()或结合Vue Router进行编程式导航。以下是具体实现方法: 使用浏览器API metho…