vue中$set与$delete的使用及说明
作者:高先生的猫
这篇文章主要介绍了vue中$set与$delete的使用及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
对于对象
vue无法检测property的添加或移除,由于vue会在初始化实例时对property执行getter/setter转换,所以propterty必须在data对象上存在才能让vue将它转换为响应式的。
例如:
var vm = new vue({ data:{ a:1 } }) // `vm.a` 是响应式的 vm.b = 2 // `vm.b` 是非响应式的
对于已经创建的实例,vue不允许添加根级别的响应式属性,但是可以使用
vue.set(vm.someObject, "b" ,2)
也可以使用vm.$set实例方法,这也是全局vue.set方法的别名
this.$set(this.someObject, "b", 2)
如果为已有的对象赋值多个新property
this.someObject = Object.assign({},this.someObject,{a:1,b:2})
例子:
<div class> 参数名: <el-input style="width:170px" v-model="parKey" class="margin_r20"></el-input>参数值: <el-input style="width:170px" v-model="parName" class="margin_r10"></el-input> <el-button type="primary" size="medium" @click="addPar">增加</el-button> </div>参数列表 <ul class="parList"> <li v-for="(value, name, index) in AddEditeDialog.netTypeParam" :key="index"> {{name}} : {{value}} <el-button size="mini" round @click="delPar(name)" class="pull-right">删除</el-button> </li> </ul>
addPar() { this.parKey = this.parKey.trim(); this.parName = this.parName.trim(); this.$set(this.AddEditeDialog.netTypeParam, this.parKey, this.parName); // 不能写成this.AddEditeDialog.netTypeParam[this.parKey] = this.parKey this.parKey = ""; this.parName = ""; }, delPar(name) { this.$delete(this.AddEditeDialog.netTypeParam, name); },
对于数组
vue不能检测以下数组的变动
vm.items[indexOfItem] = newValue vm.items.length = newLength
var vm = new vue({ data: { items: ['a', 'b', 'c'] } }) vm.items[1] = 'x' // 不是响应性的 vm.items.length = 2 // 不是响应性的
vm.items[indexOfItem] = newvue // 可以采用下面2种方法实现响应式 Vue.set(vm.items, indexOfItem, newValue) || vm.$set(vm.items, indexOfItem, newValue) vm.items.splice(indexOfItem, 1, newValue) vm.items.length = newLength // 可以采用下面方法实现响应式 vm.items.splice(newLenght)
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。