拆解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'; // 嵌套属性也应该被拦截!
相关推荐
独泪了无痕4 小时前
Vue3中防御XSS攻击的“特效药”-DOMPurify
前端·vue.js·安全
小小19924 小时前
idea 配置less转化为css
前端·css·less
hhb_6184 小时前
Less嵌套避坑:优先级冲突实战解析
前端·css·less
云水一下4 小时前
Vue.js从零到精通系列(五):全局状态管理——Pinia 核心与实践
前端·javascript·vue.js
我不是外星人5 小时前
浅谈我对 AI 发展的看法
前端·ai编程·claude
甲维斯5 小时前
测一波Kimi K2.7,消耗一周配额!
前端·人工智能·游戏开发
Dick5075 小时前
ROS2 多机器人通用 Driver 层复盘:BaseRobotDriver 到多平台 Mock 切换实现
前端·javascript·机器人
xiaofeichaichai6 小时前
前端安全 XSS 与 CSRF
前端·安全·xss
JS菌6 小时前
Skills 动态加载系统:让 AI Agent 按需获取领域知识
前端·人工智能·后端