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) {
if (!value || typeof value !== 'object') {
return;
}
Object.keys(value).forEach(key => {
defineReactive(value, key, value[key]);
});
}
const user = {
name: '尤雨溪',
age: 30,
skills: {
frontend: 'Vue',
backend: 'Node'
}
};
observe(user);
console.log('--- 👉 尝试读取数据 ---');
const name = user.name;
console.log('\n--- 👉 尝试修改数据 ---');
user.age = 38;
console.log('\n--- 👉 尝试修改嵌套数据 ---');
user.skills.frontend = 'Vue 3';