H5W3
当前位置:H5W3 > HTML5 > 正文

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 v-model="parKey" class="margin_r20"></el-input>参数值:
<el-input 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)
站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/9328

未经允许不得转载:H5W3 » vue 中 $set与$delete的使用

赞 (0)

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址