国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

Vue使用Ref跨層級(jí)獲取組件的步驟

瀏覽:50日期:2022-10-09 08:16:57
Vue使用Ref跨層級(jí)獲取組件實(shí)例示例介紹

在開發(fā)過程中,我們難免會(huì)使用到跨層級(jí)的ref實(shí)例獲取,大部分情況下,我們都可以通過組件自身的parent或者children去找到需要的實(shí)例。但是當(dāng)層級(jí)不明顯或者太深的時(shí)候,用此方法難免過于臃腫和低效率。

如下圖所示,我們通過組件E去獲取組件D的組件實(shí)例。

Vue使用Ref跨層級(jí)獲取組件的步驟

文檔目錄結(jié)構(gòu)

Vue使用Ref跨層級(jí)獲取組件的步驟

分別有A、B、C、D、E和index六個(gè)組件,并按照上圖的組件順序,分別插入到各自的頁面中。

頁面樣式如下:

Vue使用Ref跨層級(jí)獲取組件的步驟

安裝vue-ref

下載vue-ref

npm install vue-ref --save

全局注冊(cè)

import ref from ’vue-ref’Vue.use(ref)

使用方法

<!-- vm.dom will be the DOM node --><p v-ref='c => this.dom = c'>hello</p><!-- vm.child will be the child component instance --><child-component v-ref='c => this.child = c'></child-component><span v-for='n in 10' :key='n' v-ref='(c, key) => {...}'>{{ n }} </span>根組件自定義方法[使用provide和inject]

我們index頁面中,提供了三個(gè)方法:分別用來:

設(shè)置子組件的實(shí)例,setChildrenRef 獲取自組件實(shí)例, getChildrenRef 獲取當(dāng)前節(jié)點(diǎn)實(shí)例, getRef

provide() { return { setChildrenRef: (name, ref) => { this[name] = ref }, getChildrenRef: name => { return this[name] }, getRef: () => { return this } } },分別說明各個(gè)頁面

組件A頁面:

Vue使用Ref跨層級(jí)獲取組件的步驟

通過注入的方法,獲取setChildrenRef方法,并通過上述指令,將組件D緩存起來

組件B頁面:

Vue使用Ref跨層級(jí)獲取組件的步驟

組件C頁面:

Vue使用Ref跨層級(jí)獲取組件的步驟

組件D頁面:

Vue使用Ref跨層級(jí)獲取組件的步驟

組件E頁面:

Vue使用Ref跨層級(jí)獲取組件的步驟

在這個(gè)頁面中,我們不僅注入了兩個(gè)方法,還設(shè)置了切換D組件顏色的方法,用來測(cè)試我們是否真的跨層級(jí)獲取到了組件D的實(shí)例。

結(jié)果

Vue使用Ref跨層級(jí)獲取組件的步驟

可以看到,三個(gè)parent的實(shí)例是一樣的,在組件E中也成功修改了組件D的文字樣式。good!

以上就是Vue使用Ref跨層級(jí)獲取組件的步驟的詳細(xì)內(nèi)容,更多關(guān)于vue 使用Ref獲取組件的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 平凉市| 肇源县| 潞城市| 土默特左旗| 长武县| 渑池县| 花莲县| 东海县| 行唐县| 伊宁县| 玉屏| 和林格尔县| 长海县| 栾城县| 邓州市| 鄂州市| 宁海县| 汶川县| 定襄县| 庐江县| 承德市| 虹口区| 申扎县| 佛教| 西藏| 拉萨市| 铁岭市| 建平县| 新沂市| 西宁市| 屯昌县| 杨浦区| 思茅市| 龙门县| 安国市| 太湖县| 汨罗市| 灵石县| 清水河县| 安义县| 化州市|