Vue3基礎(chǔ)之provide/inject依賴和注入

簡(jiǎn)述

在項(xiàng)目中严拒,父組件傳值數(shù)據(jù)給子組件,我們都知道怎么實(shí)現(xiàn)荠呐,那么父組件傳值給子組件的子組件呢赛蔫?我們一般想法是通過傳值子組件,子組件再傳值給子的子組件泥张。這樣維護(hù)不容易還容易出現(xiàn)問題呵恢,那么Vue為我們提供了provide/inject,依賴和注入媚创。

  • 誤區(qū)
    我一開始寫這個(gè)小Demo的時(shí)候瑰剃,思路是點(diǎn)擊按鈕后,數(shù)據(jù)+1筝野,再給子組件傳值晌姚,發(fā)現(xiàn)provide不能寫入到函數(shù)中,其實(shí)我們可以換一個(gè)角度歇竟,因?yàn)槭菙?shù)據(jù)綁定挥唠,所以我們只需要對(duì)數(shù)據(jù)進(jìn)行操作即可。
關(guān)鍵引入
  import {provide } from 'vue';  //提供/依賴
  import { inject } from 'vue';   // 注入
  • provide
  1. 第一個(gè)參數(shù)被稱為注入名焕议,可以是一個(gè)字符串或是一個(gè) Symbol宝磨。后代組件會(huì)用注入名來查找期望注入的值。一個(gè)組件可以
    多次調(diào)用 provide()盅安,使用不同的注入名唤锉,注入不同的依賴值。
  2. 第二個(gè)參數(shù)是提供的值别瞭,值可以是任意類型窿祥,包括響應(yīng)式的狀態(tài),比如一個(gè) ref
  3. 注入方的組件不可更改 readonly
<script setup>
import { ref, provide, readonly } from 'vue'

const count = ref(0)
provide('read-only-count', readonly(count))
</script>
  • inject
  1. 默認(rèn)情況下蝙寨,inject 假設(shè)傳入的注入名會(huì)被某個(gè)祖先鏈上的組件提供晒衩。如果該注入名的確沒有任何組件提供,則會(huì)拋出一個(gè)運(yùn)行時(shí)警告
  2. 如果在注入一個(gè)值時(shí)不要求必須有提供者墙歪,那么我們應(yīng)該聲明一個(gè)默認(rèn)值听系,和 props 類似:const value = inject('message', '這是默認(rèn)值')
結(jié)構(gòu)
  • 父組件
  • A是父的子組件
  • B是A的子組件
代碼
  • 父組件
<template>
<div> 
   <div class="div1">
       <button @click="tailNum">
           傳值子組件們
       </button> 
       <A></A>
   </div> 
</div>
</template>
<script setup>  
import {ref, provide } from 'vue'; 
import A from './A.vue';
const count = ref(0)   
provide(/* 注入名 */ 'num', /* 值 */ count)
const tailNum = ()=>{
   count.value++
} 
</script>
  • A組件
<template>
  <div>
     這是A組件,獲取到父組件信息是:{{num}}
      <B></B>
  </div>
</template>
<script setup>
  import { inject } from 'vue';
  import B from './B.vue' 
  const num = inject('num')
</script>
  • B組件
<template>
    <div>
       這是B組件,獲取到父父組件信息是:{{num}}
    </div>
  </template>
  <script setup> 
  import { inject } from 'vue';
  const num = inject('num')
  </script> 
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市虹菲,隨后出現(xiàn)的幾起案子靠胜,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件浪漠,死亡現(xiàn)場(chǎng)離奇詭異菠赚,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)郑藏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門衡查,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人必盖,你說我怎么就攤上這事拌牲。” “怎么了歌粥?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵塌忽,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我失驶,道長(zhǎng)土居,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任嬉探,我火速辦了婚禮擦耀,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘涩堤。我一直安慰自己眷蜓,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布胎围。 她就那樣靜靜地躺著吁系,像睡著了一般。 火紅的嫁衣襯著肌膚如雪白魂。 梳的紋絲不亂的頭發(fā)上汽纤,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音福荸,去河邊找鬼蕴坪。 笑死,一個(gè)胖子當(dāng)著我的面吹牛逞姿,可吹牛的內(nèi)容都是我干的辞嗡。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼滞造,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了栋烤?” 一聲冷哼從身側(cè)響起谒养,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后买窟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體丰泊,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年始绍,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了瞳购。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡亏推,死狀恐怖学赛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情吞杭,我是刑警寧澤盏浇,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站芽狗,受9級(jí)特大地震影響绢掰,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜童擎,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一滴劲、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧顾复,春花似錦哑芹、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至乙嘀,卻和暖如春末购,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背虎谢。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來泰國打工盟榴, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人婴噩。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓擎场,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親几莽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子迅办,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

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