對於對象
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 // 不是響應性的
秒收目錄站https://www.tomove.com.cn
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)