vue中$set與$delete的使用及說明
更新時間:2023年10月27日 08:59:48 作者:高先生的貓
這篇文章主要介紹了vue中$set與$delete的使用及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
對于對象
vue無法檢測property的添加或移除,由于vue會在初始化實例時對property執(zhí)行g(shù)etter/setter轉(zhuǎn)換,所以propterty必須在data對象上存在才能讓vue將它轉(zhuǎn)換為響應(yīng)式的。
例如:
var vm = new vue({ data:{ a:1 } }) // `vm.a` 是響應(yīng)式的 vm.b = 2 // `vm.b` 是非響應(yīng)式的
對于已經(jīng)創(chuàng)建的實例,vue不允許添加根級別的響應(yīng)式屬性,但是可以使用
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> 參數(shù)名: <el-input style="width:170px" v-model="parKey" class="margin_r20"></el-input>參數(shù)值: <el-input style="width:170px" v-model="parName" class="margin_r10"></el-input> <el-button type="primary" size="medium" @click="addPar">增加</el-button> </div>參數(shù)列表 <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); },
對于數(shù)組
vue不能檢測以下數(shù)組的變動
vm.items[indexOfItem] = newValue vm.items.length = newLength
var vm = new vue({ data: { items: ['a', 'b', 'c'] } }) vm.items[1] = 'x' // 不是響應(yīng)性的 vm.items.length = 2 // 不是響應(yīng)性的
vm.items[indexOfItem] = newvue // 可以采用下面2種方法實現(xiàn)響應(yīng)式 Vue.set(vm.items, indexOfItem, newValue) || vm.$set(vm.items, indexOfItem, newValue) vm.items.splice(indexOfItem, 1, newValue) vm.items.length = newLength // 可以采用下面方法實現(xiàn)響應(yīng)式 vm.items.splice(newLenght)
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。