一起学Vue3源码,实现最简Vue3 - 实现 reactive 和 readonly 嵌套对象转换功能
// 引入 reactive 和 readonly 函数
import { reactive, readonly } from "./reactive";
// 测试用的数据
const original = {
nested: {
foo: 1,
},
};
// 使用 reactive 创建响应式对象
const reactiveObj = reactive(original);
// 使用 readonly 创建只读的响应式代理
const readonlyObj = readonly(reactiveObj);
// 修改原始对象的嵌套属性
original.nested.foo = 2;
// 输出结果,可以看到 reactiveObj 和 readonlyObj 的变化
console.log(reactiveObj.nested.foo); // 输出 2
console.log(readonlyObj.nested.foo); // 输出 2
// 尝试修改只读对象,将会抛出错误
// 注意:在实际的 Vue 3 源码中,这里会有更复杂的错误处理逻辑
try {
readonlyObj.nested.foo = 3;
} catch (e) {
console.log(e.message); // 输出错误信息
}
这段代码演示了如何使用我们实现的 reactive
和 readonly
函数来创建响应式和只读的对象。它还演示了如何处理对只读对象的修改尝试,在实际的 Vue 3 中,这将触发更多的错误处理逻辑。
评论已关闭