拆解Vue2源码-01 reactive

js 复制代码
// Step 1: 简单的属性拦截器
// 尤雨溪的核心思路:利用 Object.defineProperty 拦截属性的读取(get)和修改(set)

function defineReactive(obj, key, val) {
  // 递归观察子对象
  observe(val);

  Object.defineProperty(obj, key, {
    enumerable: true,
    configurable: true,
    get() {
      console.log(`🔍 属性 [${key}] 被读取了,当前值是:`, val);
      return val;
    },
    set(newVal) {
      if (newVal === val) return;
      console.log(`✍️ 属性 [${key}] 被修改了,旧值: [${val}], 新值: [${newVal}]`);
      val = newVal;
      // 新赋的值如果也是对象,需要继续观察
      observe(newVal);
    }
  });
}

function observe(value) {
  // 如果不是对象或者是 null,就不需要观察
  if (!value || typeof value !== 'object') {
    return;
  }
  
  // 遍历对象的所有属性,进行拦截
  Object.keys(value).forEach(key => {
    defineReactive(value, key, value[key]);
  });
}

// ==================== 测试我们的 Step 1 ====================
const user = {
  name: '尤雨溪',
  age: 30,
  skills: {
    frontend: 'Vue',
    backend: 'Node'
  }
};

// 激活响应式!
observe(user);

console.log('--- 👉 尝试读取数据 ---');
const name = user.name; // 应该触发 get

console.log('\n--- 👉 尝试修改数据 ---');
user.age = 38; // 应该触发 set

console.log('\n--- 👉 尝试修改嵌套数据 ---');
user.skills.frontend = 'Vue 3'; // 嵌套属性也应该被拦截!
相关推荐
ZC跨境爬虫6 小时前
跟着 MDN 学CSS day_10:(博客页面样式修复实战挑战)
前端·css
宋浮檀s6 小时前
DVWA通关教程2
运维·服务器·前端·javascript
前端爆冲6 小时前
基于SSE实现AI聊天场景的流式输出
前端·ai编程
Bigger6 小时前
mini-cc 技术栈:跟着 Claude Code 先选 TypeScript + React + Ink
前端·ai编程·claude
vortex57 小时前
XSS 漏洞深度挖掘与利用:从自动化扫描到账户接管
前端·自动化·xss
光影少年7 小时前
前端浏览器自动化
运维·前端·前端框架·自动化
弹简特7 小时前
【Vue3速成】04-vue3官方库-路由机制
前端·vue·路由
threelab7 小时前
Three.js 抽象艺术着色器效果 | 三维可视化 / AI 提示词
前端·javascript·人工智能·3d·着色器
萌新小码农‍7 小时前
Python的input函数
java·前端·python