大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專(zhuān)注Java教育14年 全國(guó)咨詢/投訴熱線:400-8080-105
動(dòng)力節(jié)點(diǎn)LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁(yè) hot資訊 給Vue對(duì)象增加響應(yīng)式屬性

給Vue對(duì)象增加響應(yīng)式屬性

更新時(shí)間:2022-03-16 10:57:07 來(lái)源:動(dòng)力節(jié)點(diǎn) 瀏覽3025次

Vue.$set給對(duì)象新增屬性

Vue.$set()

Object.assign()

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

vue代碼中,只要在data對(duì)象里定義的對(duì)象,賦值后,任意一個(gè)屬性值發(fā)生變化,視圖都會(huì)實(shí)時(shí)變化

比如下面在data定義了obj對(duì)象,mounted里賦值后,(也可以在其他地方賦值)只要obj.a或者obj.b的值改變了,視圖會(huì)跟著變化。

data() {
	return {
		obj: {}
	}
},
mounted: {
	this.obj = {a:1, b: 2} // 改變this.obj.a this.obj.c的值視圖會(huì)更新
	this.obj.c = 3 // 改變this.obj.c的值  視圖不會(huì)更新
	Object.assign(this.obj, {d: 4}) // 改變this.obj.c的值 視圖不會(huì)更新
	this.$set(this.obj, 'e', 5) // 改百年this.obj.e時(shí) 視圖會(huì)更新
	console.log('obj' + this.obj)
}

但是我們?cè)趏bj對(duì)象上新增的屬性變化時(shí),值會(huì)變化,但是視圖不會(huì)實(shí)時(shí)變化

比如obj.c或者obj.d變化時(shí),值雖然會(huì)變,但是視圖不會(huì)跟著變

Vue.$set()

使用Vue.$set()方法,既可以新增屬性,又可以觸發(fā)視圖更新,比如obj.e改變時(shí),視圖會(huì)相應(yīng)改變

打印出的obj,可以看出,新增的屬性只有通過(guò)this.set()的obj.e屬性有g(shù)et和set方法的,而新增的obj.c和obj.d沒(méi)有

根據(jù)官方文檔定義:如果在實(shí)例創(chuàng)建之后添加新的屬性到實(shí)例上,它不會(huì)觸發(fā)視圖更新。

當(dāng)我們把一個(gè)JavaScript 對(duì)象傳入 Vue 實(shí)例作為 data 選項(xiàng),Vue 將遍歷此對(duì)象所有的屬性,并使用 Object.defineProperty把這些屬性全部轉(zhuǎn)為 getter/setter。

Object.assign()

給data定義的對(duì)象新增屬性,同時(shí)又要視圖實(shí)時(shí)更新,除了用Vue.$set()方法,也可以通過(guò)Object.assign()實(shí)現(xiàn)

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)

	// 下面這一行代碼才觸發(fā)了視圖更新
    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()方法不生效時(shí),改用Object.assign()試試

使用this.$set()去改變一個(gè)傳入組件的對(duì)象(沒(méi)有直接定義在data對(duì)象中,通過(guò)mixins選項(xiàng)做相關(guān)操作,能夠通過(guò)this.去獲取),沒(méi)有觸發(fā)視圖更新

而改用Object.assign()去給對(duì)象重新賦值時(shí),會(huì)觸發(fā)視圖更新

通過(guò)重新給對(duì)象賦值,來(lái)使視圖更新;

使用Object.assign()新增,或者改變?cè)袑?duì)象,

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

以上就是關(guān)于“給Vue對(duì)象增加響應(yīng)式屬性”的介紹,大家如果想了解更多相關(guān)知識(shí),不妨來(lái)關(guān)注一下動(dòng)力節(jié)點(diǎn)的Java視頻,里面的課程內(nèi)容細(xì)致全面,由淺到深,通俗易懂,適合沒(méi)有基礎(chǔ)的小伙伴學(xué)習(xí),希望對(duì)大家能夠有所幫助。

提交申請(qǐng)后,顧問(wèn)老師會(huì)電話與您溝通安排學(xué)習(xí)

免費(fèi)課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 欧美洲大黑香蕉在线视频 | 欧美在线观看高清一二三区 | 97在线观看免费版 | 丁香六月色婷婷 | 黄在线免费看 | 中国特级黄一级真人毛片 | 午夜精品福利影院 | 国产精品二区页在线播放 | 一道本一区二区三区 | 欧美日韩国产中文字幕 | 亚洲国产欧美久久香综合 | 性生活视频免费观看 | 国产美女久久久亚洲 | 国产草比| 欧美激情一区二区三级高清视频 | 看一级毛片一区二区三区免费 | 国产精品免费播放 | 四虎最新紧急更新地址 | 色骚综合| 成人a区| 欧美精品午夜毛片免费看 | 亚洲综合色色图 | 久久久久久综合对白国产 | 国产精品原创永久在线观看 | 91国自产精品中文字幕亚洲 | 天天干夜夜谢 | 国产91精品久久久久999 | 99视频久久精品久久 | 久久久国产一区二区三区 | 88国产经典欧美一区二区三区 | 九九热在线精品视频 | 亚洲欧美国产毛片在线 | 爱爱毛片 | 久久国产精品自由自在 | aaa毛片在线| 免费看欧美一级特黄a毛片 免费看欧美一级特黄α大片 | 亚洲精品亚洲人成在线播放 | 久久涩综合 | 四虎影视在线看免费 720p | 国产日韩精品视频一区二区三区 | 快播视频在线 |