99久久精品国产片-99久久精品国产免费-99久久精品国产麻豆-99久久精品国产国产毛片-99久久精品国产高清一区二区-99久久精品费精品国产一区二区

Vue 組件通信(父傳子,子傳父,跨組件傳值)

2021-10-9    前端達人

目錄

一, 簡單介紹組件通信

二, 詳解傳值方法

1.父傳子 props

2.子傳父 $emit

3.跨組件通信 event-bus


一, 簡單介紹組件通信

        我們知道在現在的開發環境下,不管前后端開發都是組件化模塊化,這是因為組件的優勢無比的巨大,可以進行多次的復用增加開發效率,也可以分類鮮明,便于維護,而我今天所寫的就是開發中分割成不同的組件互相傳遞數據和互動

        我的工作中常用地組件通信大致分為三類: 父傳子 , 子傳父 , 跨組件傳值

        下面就來分別介紹一下 我常用的這三種傳值方法

二, 詳解傳值方法

        父子組件的確認方法:我將 B 組件import引入到 A 組件中,那么 B 就是 A 的子組件,A 就是 B 的父組件

1.父傳子 props

        簡而言之,父傳子就是父組件把數據傳給子組件,具體就是如下,在子組件的props中定義自定義屬性來待接收父組件的數據,有兩種方法 如下:

        第一種,也是最推薦用的一種,以復雜類型的方式進行聲明,這樣存儲的便是一個地址,可以和父組件的數據進行雙向綁定,同步數據,雖然可以雙向綁定,但是在Vue2.0中還是不可以直接在子組件中更改父組件的數據,需要用到子傳父才行,這點等下會寫到

        這里只是用 text 舉個栗子,具體叫什么都可以哈,只是父子里面需要對應上相同

        這個 text 接收到數據后的使用方法和一般data中聲明的變量一樣,只是不能再子組件中改變他

子組件中:        props 定義屬性接收

 
  1. <template>
  2. <div>
  3. <h2>son組件</h2>
  4. <p>props:{{ text }}</p>
  5. </div>
  6. </template>
  7. <script>
  8. export default {
  9. // 在此處定義props
  10. props: {
  11. // props中定義 接收父組件數據的自定義屬性,叫什么都可以,我隨便起了個text
  12. text: {
  13. type: String, // type 是用來規定此屬性接收到的數據的數據類型
  14. default: "未傳遞時默認的文字" // 這個default是當這個 text 沒有接收到傳遞的數據時的默認值
  15. }
  16. }
  17. }
  18. </script>

父組件中:        標簽內 傳遞數據

 
  1. <template>
  2. <div id="app">
  3. <!--
  4. 這里的text就是子組件props里定義的text,這兩個名字得一致
  5. 并且傳遞的數據也要符合 type 規定的數據類型
  6. text就是傳遞字符串,:text就是傳遞動態數據
  7. -->
  8. <Son text="我是大娃 傳給子啦" />
  9. <Son :text="wenzi" />
  10. </div>
  11. </template>
  12. <script>
  13. import Son from './components/son.vue';
  14. export default {
  15. data () {
  16. return {
  17. wenzi: '我是二娃 傳給子啦'
  18. }
  19. },
  20. components: {
  21. Son
  22. }
  23. }
  24. </script>

        如上 雖然我的注釋寫的很清楚了,但是還是在介紹一下, <Son/> 是子組件的標簽,在此標簽的基礎上書寫 子組件props 定義的屬性名,并且傳遞參數具體對應關系和效果如下:

        如上就是第一種我最常用的父傳子,其實還有一種方法,但是我一般也不用,很不方便,也貼到下邊了,這個是以數組方式聲明

 
  1. export default {
  2. // 在此處定義props
  3. props: ['text']
  4. }
  5. </script>

 

2.子傳父 $emit

        剛剛說到了在 Vue2.0 子組件不能直接改父組件的數據,否則會報錯,這個解決方法就是在子組件中發起一個 自定義事件 ,在父組件監聽這個事件,并且定義一個函數來改變數據,具體操作如下:

子組件:        發起一個自定義事件,等待父組件監聽到執行函數

 
  1. <template>
  2. <div>
  3. <h2>son組件</h2>
  4. <p>props:{{ text }}</p>
  5. <button @click="changeTextFn">改變文字</button>
  6. </div>
  7. </template>
  8. <script>
  9. export default {
  10. // 在此處定義props
  11. props: {
  12. // props中定義 接收父組件數據的自定義屬性,叫什么都可以,我隨便起了個text
  13. text: {
  14. type: String, // type 是用來規定此屬性接收到的數據的數據類型
  15. default: "未傳遞時默認的文字" // 這個default是當這個 text 沒有接收到傳遞的數據時的默認值
  16. }
  17. },
  18. methods: {
  19. // 按鈕點擊事件
  20. changeTextFn () {
  21. // 發起自定義事件,名字叫什么都行,第一個參數是事件名,之后再跟著的都是傳遞的參數
  22. this.$emit('changeFn', '我想變成三娃')
  23. }
  24. }
  25. }
  26. </script>

        我先在原有的代碼上添加了一個<button>按鈕,在點擊調用的函數中,通過 $emit 來發起事件并且可以傳遞參數

格式:        this.$emit('changeFn', '我想變成三娃') 

格式:        this.$emit('自定義事件名', 傳遞的參數) 

 

父組件:        行內監聽子組件的 自定義事件名(函數上不用寫參數,在 methods 中直接寫形參就行)

 
  1. <template>
  2. <div id="app">
  3. <Son :text="wenzi" @changeFn="changeFn" />
  4. </div>
  5. </template>
  6. <script>
  7. import Son from './components/son.vue';
  8. export default {
  9. data () {
  10. return {
  11. wenzi: '我是二娃 傳給子啦'
  12. }
  13. },
  14. components: {
  15. Son
  16. },
  17. methods: {
  18. // 監聽子組件自定義事件
  19. changeFn (newText) {
  20. // 這里的形參接受到的就是子組件中 第二個參數傳遞的數值
  21. this.wenzi = newText
  22. }
  23. }
  24. }
  25. </script>

對應關系和效果圖如下:

 

 

 

3.跨組件通信 event-bus

        如果兩個組件的關系非常的復雜或者沒有未產生直接聯系,那么通過父子組件通訊是非常麻煩的。這時候可以使用通用的組件通訊方案:事件總線(event-bus)

        按照我的習慣,我會將事件總線創建到 main.js 中,這個使用原理是將bus掛載到Vue原型上,這樣就可以保證所有的組件都能通過 this.bus 訪問到事件總線,從而通過同一個事件總線監聽同一個事件,具體原理和父子傳參差不多,都是 $emit 傳遞數據, 只不過接收變成了$on 

        我這次以送禮物舉例用了兩個關系不大的組件 分別是 男組件 和 女組件 (隨便起的名)具體如下圖:

發送數據 男組件:   

    this.bus.$emit('自定義事件名',傳遞的參數) 

 
  1. <template>
  2. <div>
  3. <h1>男組件</h1>
  4. <button @click="sendGiftFn">送禮物</button>
  5. </div>
  6. </template>
  7. <script>
  8. export default {
  9. data () {
  10. return {
  11. gift: '玫瑰花'
  12. }
  13. },
  14. methods: {
  15. sendGiftFn () {
  16. // 通過 bus 事件總線發起 自定義事件,并且傳遞參數(第一個是事件名,第二個開始是參數)
  17. this.bus.$emit('sendMessage', this.gift)
  18. }
  19. }
  20. }
  21. </script>

接收數據 女組件:         

 this.bus.$on('監聽的事件名',(e)=>{ e這個形參所接收的就是監聽事件所攜帶的參數數據 }) 

 
  1. <template>
  2. <div>
  3. <h1>女組件</h1>
  4. <p>來自男組件的禮物:{{ info }}</p>
  5. </div>
  6. </template>
  7. <script>
  8. export default {
  9. data () {
  10. return {
  11. info: ""
  12. }
  13. },
  14. created () {
  15. // e 就是 sendMessage 這個事件所傳遞的數據
  16. this.bus.$on("sendMessage", (e) => {
  17. this.info = e;
  18. });
  19. }
  20. }
  21. </script>
  22. <style>
  23. </style>

具體效果如下:

 

綜上所述,就是我在工作中總結出來的一些組建通信的方法,希望您看到這里會有所收獲

藍藍設計建立了UI設計分享群,每天會分享國內外的一些優秀設計,如果有興趣的話,可以進入一起成長學習,請掃碼藍小助,報下信息,藍小助會請您入群。歡迎您加入噢~~希望得到建議咨詢、商務合作,也請與我們聯系。

分享此文一切功德,皆悉回向給文章原作者及眾讀者.

轉自:csdn
免責聲明:藍藍設計尊重原作者,文章的版權歸原作者。如涉及版權問題,請及時與我們取得聯系,我們立即更正或刪除。

藍藍設計www.lapeinture.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 、平面設計服務

日歷

鏈接

個人資料

藍藍設計的小編 http://www.lapeinture.cn

存檔

亚洲天堂免费观看| 高清一级片| 亚欧视频在线| 日本在线www| 麻豆系列 在线视频| 欧美1卡一卡二卡三新区| 欧美国产日韩一区二区三区| 精品久久久久久综合网| 国产亚洲免费观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产不卡精品一区二区三区| 在线观看成人网 | 国产成人啪精品视频免费软件| 国产一级生活片| 99久久精品国产片| 亚洲天堂免费观看| 成人免费观看网欧美片| 久久久久久久免费视频| 美女免费毛片| 韩国三级一区| 国产麻豆精品高清在线播放| 成人免费观看的视频黄页| 国产一区二区精品久久| 久久99这里只有精品国产| 国产麻豆精品hdvideoss| 欧美另类videosbestsex久久| 亚洲精品影院久久久久久| 天堂网中文字幕| 91麻豆国产福利精品| 欧美国产日韩一区二区三区| 欧美大片毛片aaa免费看| 欧美日本免费| 亚飞与亚基在线观看| 精品久久久久久免费影院| 二级片在线观看| 青青久在线视频| 九九久久99综合一区二区| 欧美另类videosbestsex视频| 国产极品精频在线观看| 成人a大片在线观看| 韩国三级香港三级日本三级la| 日本免费看视频| 国产a免费观看| 久久99欧美| 日本伦理片网站| 日本在线www| 国产一区二区精品久久| 91麻豆国产福利精品| 日韩专区一区| 国产麻豆精品hdvideoss| 欧美激情在线精品video| 国产麻豆精品视频| 午夜家庭影院| 国产91精品一区| 久久国产精品自线拍免费| 99色精品| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日本伦理黄色大片在线观看网站| 可以免费看污视频的网站| 国产麻豆精品| 精品在线观看国产| 美女被草网站| 免费国产在线观看| 91麻豆精品国产高清在线| 国产一区二区精品久久91| 欧美激情影院| 免费国产在线观看| 亚洲第一页乱| 一a一级片| 国产网站在线| 国产网站免费| 999精品视频在线| 亚洲天堂免费观看| 成人免费观看的视频黄页| 国产一区国产二区国产三区| 久久国产精品只做精品| 九九精品久久| 99久久精品国产高清一区二区 | 中文字幕Aⅴ资源网| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日本在线www| 久草免费在线色站| 91麻豆精品国产自产在线| 黄色免费三级| 精品国产一区二区三区久久久狼| 午夜精品国产自在现线拍| 亚洲天堂免费| 九九久久99| 精品久久久久久影院免费| 国产成人精品综合在线| 欧美a级片视频| 欧美18性精品| 韩国三级香港三级日本三级| 日韩av成人| 91麻豆精品国产高清在线| 青青青草视频在线观看| 欧美一级视| 亚洲不卡一区二区三区在线 | 国产福利免费观看| 国产一区二区精品| 日韩字幕在线| 天堂网中文字幕| 亚洲第一视频在线播放| 国产一区二区精品久| 国产一级强片在线观看| 亚欧成人乱码一区二区| 国产一区国产二区国产三区| 欧美爱色| 国产美女在线一区二区三区| 久久精品免视看国产明星| 一级女性大黄生活片免费| 午夜激情视频在线观看| 国产91精品一区| 国产精品自拍在线观看| 人人干人人草| 精品国产亚一区二区三区| 久久久久久久免费视频| 欧美大片aaaa一级毛片| 久久国产一久久高清| 99色视频在线| 欧美大片毛片aaa免费看| 精品国产一区二区三区久久久狼| 日韩欧美一及在线播放| 青青青草视频在线观看| 成人影视在线播放| 欧美激情影院| 精品国产一区二区三区久| 青青久热| 久久国产精品只做精品| 国产韩国精品一区二区三区| 四虎影视久久久| 亚洲天堂在线播放| 精品久久久久久综合网| 天天色成人| 久久国产一区二区| 国产不卡在线观看| 国产视频一区在线| 欧美1卡一卡二卡三新区| 日韩在线观看免费完整版视频| 精品视频免费看| 韩国三级视频网站| 国产麻豆精品视频| 国产欧美精品| 国产一区二区精品久久| 91麻豆国产福利精品| 欧美激情中文字幕一区二区| 日本免费看视频| 欧美爱色| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 成人影院久久久久久影院| 一级女性大黄生活片免费| 午夜激情视频在线播放| 国产成+人+综合+亚洲不卡| 国产成人啪精品视频免费软件| 国产伦久视频免费观看 视频| 国产a视频| 精品国产一区二区三区国产馆| 黄视频网站在线免费观看| 99色视频在线| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产精品1024永久免费视频 | 国产一区精品| 欧美激情影院| 美国一区二区三区| 亚洲不卡一区二区三区在线 | 青青青草影院 | 精品国产香蕉伊思人在线又爽又黄| 欧美另类videosbestsex高清| 国产a免费观看| 欧美国产日韩在线| 一级毛片看真人在线视频| 99久久网站| 国产伦久视频免费观看 视频| 尤物视频网站在线观看| 欧美一级视| 欧美18性精品| 亚洲 男人 天堂| 国产精品12| 999久久66久6只有精品| 国产一区二区福利久久| 久久精品免视看国产成人2021| 欧美一级视频免费| 人人干人人草| 九九热精品免费观看| 午夜精品国产自在现线拍| 尤物视频网站在线观看| 国产视频一区二区三区四区| 黄视频网站在线看| 成人免费观看的视频黄页| 黄视频网站在线免费观看| 国产伦精品一区三区视频| 91麻豆精品国产高清在线| 亚久久伊人精品青青草原2020| 日本特黄特黄aaaaa大片| 可以在线看黄的网站| 亚洲天堂一区二区三区四区| 精品在线视频播放| 麻豆网站在线免费观看| 一级女人毛片人一女人| 二级片在线观看|