// 使用 Vue 3 的 reactive 创建一个响应式对象
import { reactive } from 'vue';
// 创建一个响应式对象
let state = reactive({
count: 0
});
// 重新赋值给 reactive 对象的属性
state.count = 1; // 这种方式会触发视图更新
// 如果想替换整个 reactive 对象,可以这样做:
state = reactive({
count: 2
}); // 这样做不会触发视图更新,因为 state 的引用变了
// 正确的方式是使用扩展运算符或者 Object.assign 来更新对象的属性
Object.assign(state, {
count: 3
}); // 这样会触发视图更新
// 或者使用扩展运算符
state = { ...state, count: 4 }; // 这样也会触发视图更新
// 总结:直接修改 reactive 对象的属性会触发视图更新,但重新赋值整个 reactive 对象不会触发更新。
reactive
函数用于创建一个响应式对象。reactive
对象的属性(如 state.count = 1
)会触发视图更新。reactive
对象(如 state = reactive({ count: 2 })
),则不会触发视图更新,因为这会改变 state
的引用。Object.assign
或扩展运算符来更新对象的属性。上一篇:vue等待几秒
下一篇:vue查看版本
Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3
Laravel 中文站