Vue使用Ref跨層級獲取元件例項

菜小牛發表於2021-01-25

Vue使用Ref跨層級獲取元件例項

示例介紹

在開發過程中,我們難免會使用到跨層級的ref例項獲取,大部分情況下,我們都可以通過元件自身的parent或者children去找到需要的例項。但是當層級不明顯或者太深的時候,用此方法難免過於臃腫和低效率。

如下圖所示,我們通過元件E去獲取元件D的元件例項。

文件目錄結構

分別有A、B、C、D、E和index六個元件,並按照上圖的元件順序,分別插入到各自的頁面中。

頁面樣式如下:

安裝vue-ref

  1. 下載vue-ref

npm install vue-ref --save

  1. 全域性註冊
import ref from 'vue-ref'
Vue.use(ref)
  1. 使用方法
<!-- 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頁面中,提供了三個方法:分別用來:

  1. 設定子元件的例項,setChildrenRef
  2. 獲取自元件例項, getChildrenRef
  3. 獲取當前節點例項, getRef
provide() {
    return {
      setChildrenRef: (name, ref) => {
        this[name] = ref
      },
      getChildrenRef: name => {
        return this[name]
      },
      getRef: () => {
        return this
      }
    }
  },

分別說明各個頁面

元件A頁面:

通過注入的方法,獲取setChildrenRef方法,並通過上述指令,將元件D快取起來

元件B頁面:

元件C頁面:

元件D頁面:

元件E頁面:

在這個頁面中,我們不僅注入了兩個方法,還設定了切換D元件顏色的方法,用來測試我們是否真的跨層級獲取到了元件D的例項。

結果

可以看到,三個parent的例項是一樣的,在元件E中也成功修改了元件D的文字樣式。good!

相關文章