父應用
import { initGlobalState } from 'qiankun';
// 初始化 參數(shù) state,state一定要起名初始化,這里我監(jiān)聽的是closeTab
const actions = initGlobalState({ closeTab: '' });
actions.onGlobalStateChange((state, prev) => {
// state: 變更后的狀態(tài); prev 變更前的狀態(tài)
console.log('main state change', state, prev);
// 將action對象綁到Vue原型上,為了項目中其他地方使用方便
// Vue.prototype.$actions = actions;
// this.$actions.setGlobalState({
// mt: value
// });
if (state.closeTab !== '') {
// vuex里面的modules里面的mutation,已經被全局使用,不想全局可以給命名空間,另外,直接調用mutation不太好,最好使用action,也就是dispatch方式
store.commit('CLOSE_TAG', state.closeTab);
}
});
子應用
//首先在mount里掛載全局事件,可收,可發(fā)
export async function mount(props) {
console.log('bizcore mount');
// 設置主應用下發(fā)的方法
// Object.keys(props.fn).forEach(method =>{
// Vue.prototype[`$${method}`] = props.fn[method]
// })
// 設置通訊
Vue.prototype.$onGlobalStateChange = props.onGlobalStateChange;
Vue.prototype.$setGlobalState = props.setGlobalState;
render(props);
}
子應用使用全局通訊,通知父應用
this.$setGlobalState({
closeTab: tabName
});