您好,登錄后才能下訂單哦!
今天小編給大家分享一下vue組件間的通信,子組件向父組件傳值的方式是什么的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
父組件里面的子組件通過@func綁定一個函數來處理
子組件傳過來的數據
<template> <div class="app"> <input @click="sendMsg" type="button" value="給父組件傳遞值"> </div> </template> <script> export default { data () { return { //將msg傳遞給父組件 msg: "我是子組件的msg", } }, methods:{ sendMsg(){ //func: 是父組件指定的傳數據綁定的函數,this.msg:子組件給父組件傳遞的數據 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>
vuex就是把數據放到內存里面去,各個組件間都可以共享vuex里面的數據
1.在一個組件間調用this.$store.dispatch(‘findUserInfoList’, q_userInfo_form); 來觸發vuex里面函數修改vuex的數據,然后在另一個組件用計算屬性映射獲取vuex的這個屬性值,就可以實現組件間的數據傳遞
computed: mapState({ //映射vuex的相關屬性值 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); }, }
對于一些簡單的項目里的可能又不是父子組件,可能是同級組件的,另一方面又沒有必要使用Vuex,針對這種情形可以使用中央事件總線(Event Bus)來解決問題,主要用到vue對象的$on和$emit事件,在同一個vue的實例可以觸發這兩個事件,比如子組件傳遞數據到父組件,在子組件通過同一個vue對象觸發$emit事件傳遞數據,在父組件通過vue實例的$on監聽剛剛emit觸發的事件來獲取子組件傳遞過來的數據
先創建一個constantsBus.js文件,里面根據不同模塊創建相關的vue實例
/** * 不同組件間通訊用的 中央事件總線 */ import Vue from 'vue'; //用戶管理總線 export const userBus = new Vue(); //管理員管理總線 export const adminBus = new Vue();
在一個組件間調用$emit傳遞數據
//引用剛剛創建的constantsBus.js import * as constantsBus from '@/common/constantsBus';
在另個接收數據的組件用$on來監聽獲取emit傳過來的數據
created() { let that = this; //監聽子組件的事件,獲取其他組件傳遞過來的data數據 constantsBus.processBus.$on('processChooseAssessor', data => { //獲取emit觸發的processChooseAssessor事件傳遞過來的data數據 }); },
一般來說在vue的數據傳遞是在父組件傳子組件通過屬性來傳,但是通過屬性來傳值,是單向的,子組件不能修改父組件的prop值,如果在子組件里面修改父組件傳過來的prop屬性值,會報錯,但是也有例外,對象類型的除外,如果父組件傳給子組件的屬性是對象的話,是可以修改對象里面的值的,并且修改后也對父組件可見,因為對象的話最后的引用都是指向同一塊內存,不受子組件不可以修改父組件的屬性約束。(不過不建議這樣處理,子組件可以修改父組件的屬性會污染數據傳遞,可能以后在那個子組件改了都不知道,一般對象的傳遞要深拷貝)
調用子組件的方法獲取子組件的數據
1.在子組件寫一個獲取數據的方法
2.父組件通過子組件的ref調用這個方法獲取子組件的數據
<trademark-file-upload ref="trademarkFileUpload" :uploadFileList="uploadFileList"></trademark-file-upload> <script> let fileList = this.$refs.trademarkFileUpload.getFileList(); <script>
以上就是“vue組件間的通信,子組件向父組件傳值的方式是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。