PHP前端开发

vue中$set的原理

百变鹏仔 3个月前 (09-25) #VUE
文章标签 原理
vue.js 中 $set 方法通过依赖追踪系统添加/修改响应式对象属性,并触发相关组件视图更新。它是通过调用 vue.util.definereactive 方法,标记属性为可观测的并设置 getter/setter 函数来实现的。

Vue.js 中 $set 的原理

在 Vue.js 中,$set 方法用于向响应式对象添加或修改一个属性。它背后的原理是:

Vue.js 使用依赖追踪系统来监视数据的变化。当一个响应式对象的属性被修改时,系统将通知所有依赖于该属性的组件,从而触发视图更新。

$set 方法会将一个新属性添加到响应式对象,或修改一个现有属性的值,同时触发依赖追踪系统,确保所有依赖于该属性的组件都能够更新。

立即学习“前端免费学习笔记(深入)”;

内部实现:

$set 方法实际上是一个包装函数,它调用 Vue.util.defineReactive 方法将新的属性添加到响应式对象。该方法将属性标记为可观测的,并设置 getter 和 setter 函数来触发依赖追踪。

用法:

$set 方法通常用于在 Vue.js 中动态地修改响应式数据的属性。以下示例展示了如何使用它:

const data = {  message: 'Hello, Vue!'};this.$set(data, 'newMessage', 'This is a new message');

在上面的示例中,$set 方法将一个新属性 newMessage 添加到 data 对象中,值为 This is a new message。这将触发所有依赖于 data 对象的组件更新,以显示新的消息。