| | |
| | | import Vue from "vue"; |
| | | import App from "./App.vue"; |
| | | import less from "less"; |
| | | import "./books/childHealth/assets/main.less"; |
| | | // 学前儿童卫生与健康 |
| | | // import "./books/childHealth/assets/main.less"; |
| | | |
| | | // import './books/content/css/default.less'; |
| | | // 嵌入式组态控制技术 |
| | | import './books/embedded/assets/main.less'; |
| | | import ElementUI from "element-ui"; |
| | | import "element-ui/lib/theme-chalk/index.css"; |
| | | import store from "./store"; |
| | |
| | | let instance = null; |
| | | |
| | | function render(props = {}) { |
| | | const { container } = props; |
| | | const { container, onGlobalStateChange, setGlobalState } = props; |
| | | Vue.prototype.onGlobalStateChange = onGlobalStateChange; |
| | | Vue.prototype.setGlobalState = setGlobalState; |
| | | Vue.prototype.container = container; |
| | | instance = new Vue({ |
| | | // router, |
| | | store, |
| | |
| | | // qiankun |
| | | export async function bootstrap() {} |
| | | export async function mount(props) { |
| | | console.log(props, "子层获取的props"); |
| | | console.log(props, "子层propspropspropsprops"); |
| | | props.onGlobalStateChange((state, prev) => { |
| | | // state: 变更后的状态; prev 变更前的状态 |
| | | console.log("子层change:",state, prev); |
| | | if (state.bb) state.bb(123) |
| | | console.log("子层变化:", state, prev); |
| | | // 状态变化同步vuex,用于各页面调用 |
| | | store.commit("setQiankun", state); |
| | | }); |
| | | |
| | | props.setGlobalState({ |
| | | aa: 2 |
| | | state: 3, // 应用挂载完成,同时用于触发一次stateChange将state挂载在vuex当中 |
| | | }); |
| | | |
| | | render(props); |
| | |
| | | instance = null; |
| | | } |
| | | |
| | | // new Vue({ |
| | | // store, |
| | | // render: (h) => h(App) |
| | | // }).$mount("#app"); |
| | | // 增加 update 钩子以便主应用手动更新微应用 |
| | | // export async function update(props) { |
| | | // render(props); |
| | | // } |