$set()在Vue2.0中正确添加属性并触发视图更新
版权申诉
![](https://csdnimg.cn/release/wenkucmsfe/public/img/starY.0159711c.png)
Vue2.0中的`$set()`方法是为了解决在数据对象上动态添加或修改属性时,无法触发视图更新的问题。在默认情况下,Vue.js通过依赖收集机制跟踪对象属性的变化,但当在已初始化实例后直接给对象添加新属性时,由于JavaScript引擎(如ES5)的限制,Vue可能无法感知这种变化,因此视图不会更新。
`$set()`方法的作用是显式地告诉Vue检测到这个属性的变化,确保视图能正确地响应。正确的使用姿势是向`data`对象的深层路径设置属性,而不是直接设置对象的某个属性。以下是使用`$set()`的示例:
```javascript
data() {
return {
student: {
name: '',
sex: ''
}
}
}
mounted() {
// 正确的使用方式
this.$set(this.student, 'age', 24);
}
```
在这个例子中,`this.$set(this.student, "age", 24)`明确地指示Vue应该将`age`属性视为data的一部分,并在视图中反映出来。这样做是因为`$set()`会为新添加的属性创建一个响应式的引用,使得当`age`的值改变时,视图会自动更新。
此外,还提到了`Vue.set()`,这是Vue 1.x版本中提供的方法,但在Vue 2.0中已经被`$set()`所取代,所以推荐使用`$set()`。在实际项目中,除非有兼容性需求,否则应避免使用`Vue.set()`。
对于场景应用,比如在一个列表渲染中,即使在点击事件后修改数组元素,如果没有使用`$set()`,也会出现问题。例如,下面的代码片段中,尽管修改了`items`数组的第1个元素,但由于没有使用`$set()`,视图不会更新:
```javascript
methods: {
btn() {
this.items[1] = 'two'; // 这里直接修改数组元素,视图不会更新
console.log(this.items);
}
}
```
为了修复这个问题,应在修改数组元素时使用`$set()`,如下所示:
```javascript
methods: {
btn() {
this.$set(this.items, 1, 'two'); // 使用$set()确保视图更新
console.log(this.items);
}
}
```
总结起来,Vue2.0中的`$set()`方法是处理动态添加、删除或更新对象属性,以确保视图响应性的重要工具。正确理解并熟练运用`$set()`可以避免在开发过程中遇到不必要的视图更新问题。
685 浏览量
点击了解资源详情
123 浏览量
253 浏览量
160 浏览量
2020-08-27 上传
333 浏览量
164 浏览量
228 浏览量
![](https://profile-avatar.csdnimg.cn/default.jpg!1)
weixin_38626075
- 粉丝: 7
最新资源
- BosonNetSim CCNP教程:入门与界面详解
- uC/OS-II操作系统实战:邵贝贝版电子书解析
- Inno Setup安装程序制作指南
- C#实用代码:高效读取Excel数据到DataSet
- JavaScript 弹窗技术大全:全屏、F11、固定尺寸与对话框示例
- VC++数据库开发:数据展示与操作详解
- Spring.NET 1.12 官方文档:Inversion of Control 和 IoC 容器详解
- LL(1)分析法:从输入'i+i*i$'到语法树的逐步解析
- Rational ClearCase LT入门与系统架构详解
- Rational ClearQuest:缺陷跟踪与管理指南
- 深入解析JavaScript浏览器对象与导航控制
- Flex3与.NET开发Flash Remoting:环境配置与步骤详解
- JavaServerPages Standard Tag Library (JSTL) 1.1 英文规范
- Spring、iBatis和WebWork框架集成实现Oracle数据库连接
- SDRAM内存模组详解:物理Bank与芯片位宽
- 使用VS.NET构建SQL Server数据库应用详解