淺談vue非父子組件通信

我們實(shí)際編寫項(xiàng)目時(shí)往往離不開組件之間的相互通信唯灵,但是這之間如何通信呢亥曹?一般大家可能首先想到props嘉抓,或者是vuex禽拔,今天老將軍換個(gè)新把式刘离,咱說下另外兩個(gè)

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


    props1.png

    改為Provide / Inject方式后


    props2.png

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

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

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

大家都知道props是有默認(rèn)值的,在沒有值傳遞過來時(shí)默認(rèn)數(shù)值是多少苦蒿,那inject有沒有呢殴胧,答案是有的,如果我們provide沒有傳遞值時(shí)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)建一個(gè)3的事件車力惯。mitt是一個(gè)體積極小的第三方消息發(fā)布/訂閱式JavaScript庫,與框架無關(guān)召嘶,所以不論是React還是Vue都可以用父晶,示例:

//導(dǎo)入
import mitt from "mitt"
const emitter=mitt()
export default emitter
//用法
import emitter from "xxx";
//觸發(fā)調(diào)用
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ù)據(jù)
//取消所有emitter監(jiān)聽
emitter.all.clear()
//創(chuàng)建及移除
function clickMe {}
emitter.on('clickMe', clickMe)   // listen
emitter.off('clickMe', clickMe) 

鐺鐺鐺~撒花完結(jié)??弄跌,如有不對甲喝,歡迎指正

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市碟绑,隨后出現(xiàn)的幾起案子俺猿,更是在濱河造成了極大的恐慌,老刑警劉巖格仲,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件押袍,死亡現(xiàn)場離奇詭異,居然都是意外死亡凯肋,警方通過查閱死者的電腦和手機(jī)谊惭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來侮东,“玉大人圈盔,你說我怎么就攤上這事∏难牛” “怎么了驱敲?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長宽闲。 經(jīng)常有香客問我众眨,道長,這世上最難降的妖魔是什么容诬? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任娩梨,我火速辦了婚禮,結(jié)果婚禮上览徒,老公的妹妹穿的比我還像新娘狈定。我一直安慰自己,他們只是感情好习蓬,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布纽什。 她就那樣靜靜地躺著,像睡著了一般友雳。 火紅的嫁衣襯著肌膚如雪稿湿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天押赊,我揣著相機(jī)與錄音饺藤,去河邊找鬼。 笑死流礁,一個(gè)胖子當(dāng)著我的面吹牛涕俗,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播神帅,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼再姑,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了找御?” 一聲冷哼從身側(cè)響起元镀,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤绍填,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后栖疑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體讨永,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年遇革,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了卿闹。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,795評論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡萝快,死狀恐怖锻霎,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情揪漩,我是刑警寧澤旋恼,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站氢拥,受9級特大地震影響蚌铜,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜嫩海,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一冬殃、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧叁怪,春花似錦审葬、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至血柳,卻和暖如春官册,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背难捌。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工膝宁, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人根吁。 一個(gè)月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓员淫,卻偏偏與公主長得像,于是被迫代替她去往敵國和親击敌。 傳聞我的和親對象是個(gè)殘疾皇子介返,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容