淺談vue非父子組件通信

我們實際編寫項目時往往離不開組件之間的相互通信,但是這之間如何通信呢?一般大家可能首先想到props,或者是vuex,今天老將軍換個新把式,咱說下另外兩個

  • provide和inject
  • mitt
    ok,先說第一個,provide和inject。
    它用于父組件向子孫組件傳遞數(shù)據,provide在父組件中提供要傳給下級的數(shù)據,inject在需要使用這個數(shù)據的子輩組件或者孫輩等下級組件中使用數(shù)據。
    可能會有小伙伴有疑問那我props也是一樣的啊,那試想一下我們有一個大型組件樹,并且一個深度嵌套的組件需要來自遠距離祖先組件的數(shù)據。如果使用 props,我們就需要在整個父鏈中傳遞相同的 props,那不忒麻煩了,自己都寫不耐煩了而且容易出錯。在此簡單舉例:


    props1.png

    改為Provide / Inject方式后


    props2.png

    具體代碼
//APP.vue
......
  provide() {
    return {
      name: "leah",
      age: 883,
    };
  },
//HomeContent.vue
<script>
    export default {
        inject:["name","age"]
    }
</script>

provide可以使用對象形式,但是如果我們需要提供每個實例的狀態(tài),例如通過 聲明的數(shù)據data(),那么provide必須使用函數(shù)值。此外,如果為了使provide鏈接到data中的數(shù)據,我們需要使用computed()函數(shù)提供一個計算屬性

 provide() {
    return {
      message: computed(() => this.xxx)
    }
  }

大家都知道props是有默認值的,在沒有值傳遞過來時默認數(shù)值是多少,那inject有沒有呢,答案是有的,如果我們provide沒有傳遞值時HomeContent.vue可以改為

export default {
  inject: {
    name: {
      default: "leah",
    },
    age: {
      default: "12",
    },
  },
};

如果想使用別名,下面是將name改為testName,如果再使用,那就不是用this.name,而是this.testName

  inject: {
    testName: {
      from: "name",
      default: "12313",
    },
  },

接下來再說一下mitt,vue2.x有EventBus,3把它去掉了。我們可以使用mitt創(chuàng)建一個3的事件車。mitt是一個體積極小的第三方消息發(fā)布/訂閱式JavaScript庫,與框架無關,所以不論是React還是Vue都可以用,示例:

//導入
import mitt from "mitt"
const emitter=mitt()
export default emitter
//用法
import emitter from "xxx";
//觸發(fā)調用
emitter.emit("clickMe", { xx:xxx });
//監(jiān)聽某一emitter
emitter.on('clickMe', clickMe)   // listen
//監(jiān)聽所有emitter
emitter.on('*', (type, e) => console.log(type, e) ) //type為方法名,e為傳遞的數(shù)據
//取消所有emitter監(jiān)聽
emitter.all.clear()
//創(chuàng)建及移除
function clickMe {}
emitter.on('clickMe', clickMe)   // listen
emitter.off('clickMe', clickMe) 

鐺鐺鐺~撒花完結??,如有不對,歡迎指正

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容