溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

web前端開(kāi)發(fā)中父鏈和子鏈方式實(shí)現(xiàn)通信

發(fā)布時(shí)間:2020-08-04 18:52:03 來(lái)源:ITPUB博客 閱讀:137 作者:千鋒HTML5學(xué)院 欄目:移動(dòng)開(kāi)發(fā)


父鏈和子鏈?zhǔn)且环N父子間組件通信的新方式。

概念

父鏈:

在子組件中,使用this.$parent可以直接訪(fǎng)問(wèn)該組件的父實(shí)例或組件,【類(lèi)似于原生或者jquery中獲取父節(jié)點(diǎn)的方式,但是并沒(méi)有操作dom】

子鏈:

在父組件中,使用this.$children訪(fǎng)問(wèn)它所有的子組件,當(dāng)子組件較多時(shí)可以通過(guò)子組件索引名稱(chēng)來(lái)實(shí)現(xiàn)查找。【類(lèi)似于原生或者jquery中獲取子節(jié)點(diǎn)的方式】

說(shuō)明

1. this.$parent與this.$children可以無(wú)限的向上或向下訪(fǎng)問(wèn),直到根實(shí)例或最內(nèi)層組件。

2. 然后由于子組件可以有多個(gè),this.$children獲取子組件時(shí),獲取的是一個(gè)數(shù)組,要給其下標(biāo)才能獲取到具體的某一個(gè)子組件。

3. 這時(shí)操作起來(lái)不是很方便,此時(shí)我們就可以使用:子組件索引的方式實(shí)現(xiàn)獲取具體子組件

父鏈實(shí)例

web前端開(kāi)發(fā)中父鏈和子鏈方式實(shí)現(xiàn)通信

子鏈實(shí)例

web前端開(kāi)發(fā)中父鏈和子鏈方式實(shí)現(xiàn)通信

子組件索引實(shí)例

給子組件定義索引時(shí),需要在子組件調(diào)用標(biāo)簽上使用ref屬性定義,如:

web前端開(kāi)發(fā)中父鏈和子鏈方式實(shí)現(xiàn)通信

然后在父組件中獲取時(shí),通過(guò)this.$refs.refName的方式獲取具體的子組件,然后.$refs只在組件渲染完成后才會(huì)充填。

web前端開(kāi)發(fā)中父鏈和子鏈方式實(shí)現(xiàn)通信

this.$refs.sub2.submes = "來(lái)自父組件的信息--sub2";

web前端開(kāi)發(fā)中父鏈和子鏈方式實(shí)現(xiàn)通信

由于$refs是非響應(yīng)式的,所以他僅僅作為直接訪(fǎng)問(wèn)子組件的一個(gè)應(yīng)急方案。應(yīng)當(dāng)避免在計(jì)算屬性或者模板中使用$refs.

父鏈和子鏈總結(jié)

1. 父鏈與子鏈的父子組件通信方式非常相似與傳統(tǒng)的dom節(jié)點(diǎn)通信方式,當(dāng)然他仍然沒(méi)有去操作dom節(jié)點(diǎn),他操作的仍然是數(shù)據(jù)。

2. 不過(guò)這種方式會(huì)讓父子組件間出現(xiàn) 緊耦合 很難看清他們的狀態(tài),因?yàn)樗S時(shí)可能會(huì)被任意組件修改,所以這種方式并不推薦!

3. 父子組件通信最好還是使用props與【自定義事件+$emit】的方式來(lái)通信。

4. 跨級(jí)組件間的通信還是使用中央事件總線(xiàn)的方式實(shí)現(xiàn)通信?!綽us.$emit(),bus.$on()】

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI