91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么給Vue對象增加響應式屬性

發布時間:2022-09-30 17:30:44 來源:億速云 閱讀:222 作者:iii 欄目:開發技術

這篇文章主要講解了“怎么給Vue對象增加響應式屬性”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么給Vue對象增加響應式屬性”吧!

Vue.$set給對象新增屬性

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對象增加響應式屬性

Vue.$set()

怎么給Vue對象增加響應式屬性

使用Vue.$set()方法,既可以新增屬性,又可以觸發視圖更新,比如obj.e改變時,視圖會相應改變

怎么給Vue對象增加響應式屬性

打印出的obj,可以看出,新增的屬性只有通過this.set()的obj.e屬性有get和set方法的,而新增的obj.c和obj.d沒有

根據官方文檔定義:如果在實例創建之后添加新的屬性到實例上,它不會觸發視圖更新。

當我們把一個JavaScript 對象傳入 Vue 實例作為 data 選項,Vue 將遍歷此對象所有的屬性,并使用 Object.defineProperty把這些屬性全部轉為 getter/setter。

Object.assign()

給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 }
}

怎么給Vue對象增加響應式屬性

$set()方法不生效時,改用Object.assign()試試

使用this.$set()去改變一個傳入組件的對象(沒有直接定義在data對象中,通過mixins選項做相關操作,能夠通過this.去獲取),沒有觸發視圖更新

而改用Object.assign()去給對象重新賦值時,會觸發視圖更新

通過重新給對象賦值,來使視圖更新;

使用Object.assign()新增,或者改變原有對象,

// 起作用的是給對象重新賦值this.obj = Object.assign({}, this.obj, {e: 5})

感謝各位的閱讀,以上就是“怎么給Vue對象增加響應式屬性”的內容了,經過本文的學習后,相信大家對怎么給Vue對象增加響應式屬性這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

广宁县| 兴仁县| 马边| 明水县| 九龙坡区| 四会市| 固镇县| 葵青区| 施甸县| 尚志市| 毕节市| 武清区| 巴南区| 行唐县| 泰安市| 察哈| 海盐县| 琼结县| 锦屏县| 博乐市| 宣化县| 满洲里市| 庆安县| 巴林右旗| 邵东县| 陆川县| 阳朔县| 福建省| 友谊县| 阿图什市| 罗江县| 新田县| 丽水市| 沙田区| 上饶县| 丰镇市| 武鸣县| 青龙| 武陟县| 漠河县| 团风县|