vue 組件間的通信之子組件向父組件傳值的方式
父組件向子組件傳值:父組件通過(guò)屬性向下傳值的方式和子組件通信;
使用步驟:
定義組件:現(xiàn)有自定義組件com-a、com-b,com-a是com-b的父組件;
準(zhǔn)備獲取數(shù)據(jù):com-b要獲取父組件data中的name屬性;
在<com-b :name=“name”></com-b>
使用v-bind 綁定name屬性,紅色部分為屬性名稱,可以隨意寫(xiě)。
在子組件定義部分里添加選項(xiàng),值是個(gè)字符串?dāng)?shù)組 props:[‘name'],將上邊紅色的屬性名稱寫(xiě)在這里;
之后就可定義在子組件中使用name屬性了;
好了,接著本文的重點(diǎn)內(nèi)容。
寫(xiě)vue,如果頁(yè)面涉及到多個(gè)組件,就會(huì)涉及組件之間的通信,可能是父子組件間的通信,也可以是同級(jí)組件間的通信,那么,vue里面的組件如何通信。一般來(lái)說(shuō)在vue的數(shù)據(jù)傳遞是在父組件傳子組件通過(guò)屬性來(lái)傳,子組件傳父組件通過(guò)事件來(lái)傳值。
1. 子組件通過(guò)通過(guò)this.$emit()的方式將值傳遞給父組件;
2. 通過(guò)vuex來(lái)傳遞組件間的數(shù)據(jù);
3. 通過(guò)中央總線來(lái)傳遞組件間的數(shù)據(jù);
4. 通過(guò)修改父組件傳過(guò)來(lái)的對(duì)象屬性
5. 父組件使用子組件的引用ref調(diào)用子組件的方法獲取子組件的數(shù)據(jù)
一、子組件通過(guò)this.$emit()的方式將值傳遞給父組件,父組件里面的子組件通過(guò)@func綁定一個(gè)函數(shù)來(lái)處理
子組件傳過(guò)來(lái)的數(shù)據(jù)
<template> <div class="app"> <input @click="sendMsg" type="button" value="給父組件傳遞值"> </div> </template> <script> export default { data () { return { //將msg傳遞給父組件 msg: "我是子組件的msg", } }, methods:{ sendMsg(){ //func: 是父組件指定的傳數(shù)據(jù)綁定的函數(shù),this.msg:子組件給父組件傳遞的數(shù)據(jù) this.$emit('func',this.msg) } } } </script>
父組件
<template> <div class="app"> <child @func="getMsgFormSon"></child> </div> </template> <script> import child from './child.vue' export default { data () { return { msgFormSon: "this is msg" } }, components:{ child, }, methods:{ getMsgFormSon(data){ this.msgFormSon = data console.log(this.msgFormSon) } } } </script>
二、通過(guò)vuex來(lái)傳遞組件間的數(shù)據(jù)
vuex就是把數(shù)據(jù)放到內(nèi)存里面去,各個(gè)組件間都可以共享vuex里面的數(shù)據(jù)
1.在一個(gè)組件間調(diào)用this.$store.dispatch(‘findUserInfoList', q_userInfo_form); 來(lái)觸發(fā)vuex里面函數(shù)修改vuex的數(shù)據(jù),然后在另一個(gè)組件用計(jì)算屬性映射獲取vuex的這個(gè)屬性值,就可以實(shí)現(xiàn)組件間的數(shù)據(jù)傳遞
computed: mapState({ //映射vuex的相關(guān)屬性值 userInfoList: state => state.userInfoModule.userInfoList, start: state => state.userInfoModule.start, total: state => state.userInfoModule.total, }), method:{ //查詢操作 findUserInfoList: function(q_userInfoForm, start){ this.q_userInfoForm.start = (start === null) ? 1 : start; this.$store.dispatch('findUserInfoList', q_userInfo_form); }, }
三、通過(guò)中央總線來(lái)傳遞組件間的數(shù)據(jù)
對(duì)于一些簡(jiǎn)單的項(xiàng)目里的可能又不是父子組件,可能是同級(jí)組件的,另一方面又沒(méi)有必要使用Vuex,針對(duì)這種情形可以使用中央事件總線(Event Bus)來(lái)解決問(wèn)題,主要用到vue對(duì)象的
先創(chuàng)建一個(gè)constantsBus.js文件,里面根據(jù)不同模塊創(chuàng)建相關(guān)的vue實(shí)例
/** * 不同組件間通訊用的 中央事件總線 */ import Vue from 'vue'; //用戶管理總線 export const userBus = new Vue(); //管理員管理總線 export const adminBus = new Vue();
在一個(gè)組件間調(diào)用$emit傳遞數(shù)據(jù)
//引用剛剛創(chuàng)建的constantsBus.js import * as constantsBus from '@/common/constantsBus';
4. 在另個(gè)接收數(shù)據(jù)的組件用$on來(lái)監(jiān)聽(tīng)獲取emit傳過(guò)來(lái)的數(shù)據(jù)
created() { let that = this; //監(jiān)聽(tīng)子組件的事件,獲取其他組件傳遞過(guò)來(lái)的data數(shù)據(jù) constantsBus.processBus.$on('processChooseAssessor', data => { //獲取emit觸發(fā)的processChooseAssessor事件傳遞過(guò)來(lái)的data數(shù)據(jù) }); },
四、通過(guò)修改父組件傳過(guò)來(lái)的對(duì)象屬性
一般來(lái)說(shuō)在vue的數(shù)據(jù)傳遞是在父組件傳子組件通過(guò)屬性來(lái)傳,但是通過(guò)屬性來(lái)傳值,是單向的,子組件不能修改父組件的prop值,如果在子組件里面修改父組件傳過(guò)來(lái)的prop屬性值,會(huì)報(bào)錯(cuò),但是也有例外,對(duì)象類型的除外,如果父組件傳給子組件的屬性是對(duì)象的話,是可以修改對(duì)象里面的值的,并且修改后也對(duì)父組件可見(jiàn),因?yàn)閷?duì)象的話最后的引用都是指向同一塊內(nèi)存,不受子組件不可以修改父組件的屬性約束。(不過(guò)不建議這樣處理,子組件可以修改父組件的屬性會(huì)污染數(shù)據(jù)傳遞,可能以后在那個(gè)子組件改了都不知道,一般對(duì)象的傳遞要深拷貝)
五、父組件使用子組件的引用ref調(diào)用子組件的方法獲取子組件的數(shù)據(jù)
1.在子組件寫(xiě)一個(gè)獲取數(shù)據(jù)的方法
2.父組件通過(guò)子組件的ref調(diào)用這個(gè)方法獲取子組件的數(shù)據(jù)
<trademark-file-upload ref="trademarkFileUpload" :uploadFileList="uploadFileList"></trademark-file-upload> <script> let fileList = this.$refs.trademarkFileUpload.getFileList(); <script>
到此這篇關(guān)于vue 組件間的通信之子組件向父組件傳值的方式的文章就介紹到這了,更多相關(guān)vue 子組件向父組件傳值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue中v-for和v-if一起使用之使用compute的示例代碼
這篇文章主要介紹了vue中v-for和v-if一起使用之使用compute的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05Vue2.0父組件與子組件之間的事件發(fā)射與接收實(shí)例代碼
這篇文章主要介紹了Vue2.0父組件與子組件之間的事件發(fā)射與接收實(shí)例代碼,需要的朋友可以參考下2017-09-09vue 屬性攔截實(shí)現(xiàn)雙向綁定的實(shí)例代碼
這篇文章主要介紹了vue 屬性攔截實(shí)現(xiàn)雙向綁定的實(shí)例代碼,代碼簡(jiǎn)答易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-10-10Vue 頁(yè)面狀態(tài)保持頁(yè)面間數(shù)據(jù)傳輸?shù)囊环N方法(推薦)
vue router給我們提供了兩種頁(yè)面間傳遞參數(shù)的方式,一種是動(dòng)態(tài)路由匹配,一種是編程式導(dǎo)航,接下來(lái)通過(guò)本文給大家介紹Vue 頁(yè)面狀態(tài)保持頁(yè)面間數(shù)據(jù)傳輸?shù)囊环N方法,需要的朋友可以參考下2018-11-11Vue3?Radio單選切換展示不同內(nèi)容實(shí)現(xiàn)代碼
這篇文章主要介紹了Vue3?Radio單選切換展示不同內(nèi)容,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07Vue實(shí)現(xiàn)輸入框回車發(fā)送和粘貼文本與圖片功能
這篇文章主要為大家詳細(xì)介紹了Vue如何實(shí)現(xiàn)聊天輸入框回車發(fā)送、粘貼文本(包括HTML)、粘貼圖片等功能,文中的實(shí)現(xiàn)方法講解詳細(xì),需要的可以參考一下2022-05-05Vue3響應(yīng)式對(duì)象Reactive和Ref的用法解讀
這篇文章主要介紹了Vue3響應(yīng)式對(duì)象Reactive和Ref的用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09VUE使用vue?create命令創(chuàng)建vue2.0項(xiàng)目的全過(guò)程
vue-cli是創(chuàng)建Vue項(xiàng)目的一個(gè)腳手架工具,vue-cli提供了vue create等命令,下面這篇文章主要給大家介紹了關(guān)于VUE使用vue?create命令創(chuàng)建vue2.0項(xiàng)目的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07