(兩個(gè)問題為同一個(gè)答案問法不一樣)
這類問題 首先分類 表明了解的比較多 具體就沒說完 或者漏了 面試官也不會(huì)計(jì)較很多
組件通信的四大類 父與子 子與父 子與子 跨層級(jí)
在細(xì)說各種方式 加入自己的理解
1、props和$emit
父組件向子組件傳遞數(shù)據(jù)是通過prop傳遞的,子組件傳遞數(shù)據(jù)給父組件是通過$emit觸發(fā)事件
2、$attrs和$listeners
3、中央事件總線 bus
上面兩種方式處理的都是父子組件之間的數(shù)據(jù)傳遞,而如果兩個(gè)組件不是父子關(guān)系呢?這種情況下可以使用中央事件總線的方式。新建一個(gè)Vue事件bus對(duì)象,然后通過bus.$emit觸發(fā)事件,bus.$on監(jiān)聽觸發(fā)的事件。
4、provide和inject
父組件中通過provider來提供變量,然后在子組件中通過inject來注入變量。不論子組件有多深,只要調(diào)用了inject那么就可以注入provider中的數(shù)據(jù)。而不是局限于只能從當(dāng)前父組件的prop屬性來獲取數(shù)據(jù),只要在父組件的生命周期內(nèi),子組件都可以調(diào)用。
5、v-model
父組件通過v-model傳遞值給子組件時(shí),會(huì)自動(dòng)傳遞一個(gè)value的prop屬性,在子組件中通過this.$emit(‘input’,val)自動(dòng)修改v-model綁定的值
6、$parent和$children
7、boradcast和dispatch
8、vuex處理組件之間的數(shù)據(jù)交互
如果業(yè)務(wù)邏輯復(fù)雜,很多組件之間需要同時(shí)處理一些公共的數(shù)據(jù),