更新時間:2022-03-16 10:57:07 來源:動力節點 瀏覽2911次
Vue.$set()
Object.assign()
$set()方法不生效時,改用Object.assign()試試
vue代碼中,只要在data對象里定義的對象,賦值后,任意一個屬性值發生變化,視圖都會實時變化
比如下面在data定義了obj對象,mounted里賦值后,(也可以在其他地方賦值)只要obj.a或者obj.b的值改變了,視圖會跟著變化。
data() {
return {
obj: {}
}
},
mounted: {
this.obj = {a:1, b: 2} // 改變this.obj.a this.obj.c的值視圖會更新
this.obj.c = 3 // 改變this.obj.c的值 視圖不會更新
Object.assign(this.obj, {d: 4}) // 改變this.obj.c的值 視圖不會更新
this.$set(this.obj, 'e', 5) // 改百年this.obj.e時 視圖會更新
console.log('obj' + this.obj)
}
但是我們在obj對象上新增的屬性變化時,值會變化,但是視圖不會實時變化
比如obj.c或者obj.d變化時,值雖然會變,但是視圖不會跟著變
使用Vue.$set()方法,既可以新增屬性,又可以觸發視圖更新,比如obj.e改變時,視圖會相應改變
打印出的obj,可以看出,新增的屬性只有通過this.set()的obj.e屬性有get和set方法的,而新增的obj.c和obj.d沒有
根據官方文檔定義:如果在實例創建之后添加新的屬性到實例上,它不會觸發視圖更新。
當我們把一個JavaScript 對象傳入 Vue 實例作為 data 選項,Vue 將遍歷此對象所有的屬性,并使用 Object.defineProperty把這些屬性全部轉為 getter/setter。
給data定義的對象新增屬性,同時又要視圖實時更新,除了用Vue.$set()方法,也可以通過Object.assign()實現
data() {
return {
obj: {}
}
},
mounted: {
this.obj = { a: 1, b: 2 }
this.obj.c = 3
Object.assign(this.obj, { d: 4 })
// this.$set(this.obj, 'e', 5)
// 下面這一行代碼才觸發了視圖更新
this.obj = Object.assign({}, this.obj, {e: 5})
console.log("obj", this.obj)
}
以上的代碼等同于
data() {
return {
obj: {}
}
},
mounted: {
this.obj = { a: 1, b: 2, c: 3, d: 4, e: 5 }
}
$set()方法不生效時,改用Object.assign()試試
使用this.$set()去改變一個傳入組件的對象(沒有直接定義在data對象中,通過mixins選項做相關操作,能夠通過this.去獲取),沒有觸發視圖更新
而改用Object.assign()去給對象重新賦值時,會觸發視圖更新
通過重新給對象賦值,來使視圖更新;
使用Object.assign()新增,或者改變原有對象,
// 起作用的是給對象重新賦值
this.obj = Object.assign({}, this.obj, {e: 5})
以上就是關于“給Vue對象增加響應式屬性”的介紹,大家如果想了解更多相關知識,不妨來關注一下動力節點的Java視頻,里面的課程內容細致全面,由淺到深,通俗易懂,適合沒有基礎的小伙伴學習,希望對大家能夠有所幫助。
0基礎 0學費 15天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習