qiankun父子組件傳參,及main.js中使用vuex的mutation

父應用

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
      });
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容