在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/HTML/ vue兄弟之間的傳值問題

vue兄弟之間的傳值問題

圖片描述
我有個側(cè)邊列表,上面有兩個按鈕,每個按鈕都有一個組件頁面,我現(xiàn)在就是想點擊第一個按鈕的時候,彈出一個組件,是一個上傳文件功能的頁面.
我想當(dāng)我點擊上傳文件的時候
第二個按鈕對應(yīng)的組件自動彈出,并且顯示上傳文件的文件名.
用什么方法可以實現(xiàn)?
我用了兄弟之間傳值,好像不可以.

父組件是toolbar,我現(xiàn)在就是想把upload頁面里面的input file上傳的文件的名稱發(fā)給fileselector去顯示

回答
編輯回答
綰青絲

三種方案:
1.用this.$parent.$child找到想要的組件,缺點就是維護性差,子組件順序一變就會出現(xiàn)很大問題。
2.用vuex,確定就是增加的冗余代碼多,適合大項目,小項目用有點多余。
3.往window上掛屬性,缺點是自己得加監(jiān)聽,而且就是污染了window的變量。

2017年11月18日 10:08
編輯回答
遺莣

你這不是兄弟組件傳值吧,流程大概是 子組件-->父組件-->兄弟組件-->子組件

嫌麻煩的話也可以使用vuex

2018年6月1日 11:33
編輯回答
艷骨

使用vuex來管理大型項目中的數(shù)據(jù)共享與傳遞問題,鏈接:https://vuex.vuejs.org/zh-cn/

2018年1月8日 23:46
編輯回答
不歸路

先說兄弟組件數(shù)據(jù)通信:
1、使用命令行工具(CLI)構(gòu)建的Vue項目建議使用Vuex,官方也有教程,項目結(jié)構(gòu)也可以參考這里
2、如果是用<script>直接引入的Vue,可以使用一個空的Vue作為事件總線

再說解決方案:
上面兩種說的是兄弟組件間直接通信的解決方案,其實也可以通過子組件->父組件->子組件的方法解決這個問題。
FileSelector組件動態(tài)綁定父組件的屬性值(如FileNameActive),用于表示該組件的文件名顯示與否Upload組件通過$emit()方法傳遞獲取到的文件名給父組件;父組件Toolbar通過監(jiān)聽Upload的自定義事件改變FileNameActive的值,從而使得FileSelector激活并接收文件名。

2017年3月30日 16:55
編輯回答
不討囍

建議直接上手vuex,管他什么大項目小項目。用了它就沒這些煩惱了。

2017年1月21日 16:47
編輯回答
夏木

bus,通過事件傳遞
鏈接描述
看這篇文章,簡潔

1、(建議)建立一個單獨的文件bus.js

import Vue form 'vue'
export default new Vue()

2、import bus from '你的路徑/bus.js'

bus.$emit('eventName', param) //(傳遞事件)
// 在mounted中:
bus.$on('eventName', () => {'your code'}) //(接收事件)
2017年5月15日 18:03