qiankun--微前端可用小demo(主应用vue+子应用vue+子应用react)

2023-10-24 23:50

本文主要是介绍qiankun--微前端可用小demo(主应用vue+子应用vue+子应用react),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

qiankun–微前端可用小demo(主应用vue+子应用vue+子应用react)

说明:

在主应用的about页面加载子应用

成果:

加载子应用1,点击第一个按钮
请添加图片描述

子应用2,点击第二个按钮

请添加图片描述

注意:如果已经渲染一个子应用,切换另一个子应用的时候先返回about页面(自动清理上一个子应用),再点击切换按钮

代码:

主应用(vue实现)

1、初始化

使用vue-cli新建vue2项目(带router)

vue create base

安装qiankun

$ yarn add qiankun # 或者 npm i qiankun -S

2、修改main.js

import Vue from 'vue'
import App from './App.vue'
import router from './router'//引入qiankun--备份
import {registerMicroApps} from 'qiankun';
//注册app列表
const apps = [{name: 'vueApp',entry: '//localhost:9999',//自动加载,解析js,动态执行,需解决跨域container: '#cmsApp',//子应用挂载元素activeRule: '/about/cmsApp',//激活规则,访问该规则时,挂载props: {a: 1}},{name: 'reactapp',entry: '//localhost:20000',//自动加载,解析js,动态执行,需解决跨域container: '#cmsApp',activeRule: '/about/react'}
]
registerMicroApps(apps);//可以按需设置生命周期方法new Vue({router,render: h => h(App)
}).$mount('#app')

3、修改APP.vue

<template><div><!-- id --><router-link to="/">基座应用自己主页</router-link><router-link to="/about">基座应用自己about</router-link><router-view/></div>
</template><style></style>

4、修改about.vue

<template><div class="about"><p>基座的about</p><button @click="$router.push('/about/cmsApp')">调子应用</button><button @click="$router.push('/about/react')">调子应用</button><!-- 子应用挂载的节点 --><div id="cmsApp"></div></div>
</template><script>
import {start} from 'qiankun';
export default {mounted() {console.log('sss');start();//在调用页面加载}
}
</script>

5、启动

npm run serve

子应用(vue实现)

1、初始化

使用vue-cli新建vue2项目(带router)

vue create app1

2、修改main.js

import Vue from 'vue'
import App from './App.vue'
import router from './router'let instance = null;
function render() {instance = new Vue({router,render: h => h(App)}).$mount('#app')//还是渲染到自己的html里,基座会把该html挂载
};if (!window.__POWERED_BY_QIANKUN__) {//默认独立运行render();
}
if (window.__POWERED_BY_QIANKUN__) {__webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;
}
export async function bootstrap(props){};export async function mount(props){console.log(props)render()
};
export async function unmount(props){instance.$destroy()
};

3、新建vue.config.js(子应用项目根目录)


module.exports = {devServer: {port:9999,headers:{'Access-Control-Allow-Origin':'*'}},configureWebpack:{output:{library:'vueApp',libraryTarget:'umd'}}
}

4、启动

npm run serve

子应用(react实现)

a. 创建react应用

npx create-react-app my-app

b. 安装yarn

npm install -g yarn

c. 安装react-app-rewired

yarn add react-app-rewired

d. 安装react-router-dom

yarn add react-router-dom

e. 创建config-overrides.js(子应用项目根目录)

配置应用启动、打包和跨域参数

config-overrides.js

module.exports = {webpack:(config)=>{config.output.library = 'reactApp';config.output.libraryTarget = 'umd';config.output.publicPath = 'http://localhost:20000/';return config;},devServer:(configFunction)=>{return function(proxy,allowedHost){const config = configFunction(proxy,allowedHost);config.headers = {'Access-Control-Allow-Origin':'*'}return config;}}
}

f. 修改package.json

..."scripts": {"start": "react-app-rewired start","build": "react-app-rewired build","test": "react-app-rewired test","eject": "react-app-rewired eject"},...

g. 修改index.js

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
function render(){ReactDOM.render(<React.StrictMode><App /></React.StrictMode>,document.getElementById('root'));
};if(!Window.__POWERED_BY_QIANKUN__){render()
}
export async function bootstrap(props){};export async function mount(props){render()
};
export async function unmount(props){ReactDOM.unmountComponentAtNode(document.getElementById('root'))
};

h. 修改app.js


import logo from './logo.svg';
import './App.css';function App() {return (<div className="App"><header className="App-header"><img src={logo} className="App-logo" alt="logo" /><p>Edit <code>src/App.js</code> and save to reload.</p><aclassName="App-link"href="https://reactjs.org"target="_blank"rel="noopener noreferrer">Learn React</a></header></div>);
}
export default App;

i. 启动

npm start

创建react项目失败,可自行百度,index.js按照如上修改即可

 <aclassName="App-link"href="https://reactjs.org"target="_blank"rel="noopener noreferrer">Learn React</a></header>
</div>

);
}
export default App;


### i. 启动

npm start


创建react项目失败,可自行百度,index.js按照如上修改即可

这篇关于qiankun--微前端可用小demo(主应用vue+子应用vue+子应用react)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/278593

相关文章

Python使用Tkinter打造一个完整的桌面应用

《Python使用Tkinter打造一个完整的桌面应用》在Python生态中,Tkinter就像一把瑞士军刀,它没有花哨的特效,却能快速搭建出实用的图形界面,作为Python自带的标准库,无需安装即可... 目录一、界面搭建:像搭积木一样组合控件二、菜单系统:给应用装上“控制中枢”三、事件驱动:让界面“活”

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

Python Flask 库及应用场景

《PythonFlask库及应用场景》Flask是Python生态中​轻量级且高度灵活的Web开发框架,基于WerkzeugWSGI工具库和Jinja2模板引擎构建,下面给大家介绍PythonFl... 目录一、Flask 库简介二、核心组件与架构三、常用函数与核心操作 ​1. 基础应用搭建​2. 路由与参

使用Python和Tkinter实现html标签去除工具

《使用Python和Tkinter实现html标签去除工具》本文介绍用Python和Tkinter开发的HTML标签去除工具,支持去除HTML标签、转义实体并输出纯文本,提供图形界面操作及复制功能,需... 目录html 标签去除工具功能介绍创作过程1. 技术选型2. 核心实现逻辑3. 用户体验增强如何运行

Spring Boot中的YML配置列表及应用小结

《SpringBoot中的YML配置列表及应用小结》在SpringBoot中使用YAML进行列表的配置不仅简洁明了,还能提高代码的可读性和可维护性,:本文主要介绍SpringBoot中的YML配... 目录YAML列表的基础语法在Spring Boot中的应用从YAML读取列表列表中的复杂对象其他注意事项总

电脑系统Hosts文件原理和应用分享

《电脑系统Hosts文件原理和应用分享》Hosts是一个没有扩展名的系统文件,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应... Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应

CSS 样式表的四种应用方式及css注释的应用小结

《CSS样式表的四种应用方式及css注释的应用小结》:本文主要介绍了CSS样式表的四种应用方式及css注释的应用小结,本文通过实例代码给大家介绍的非常详细,详细内容请阅读本文,希望能对你有所帮助... 一、外部 css(推荐方式)定义:将 CSS 代码保存为独立的 .css 文件,通过 <link> 标签

Python使用Reflex构建现代Web应用的完全指南

《Python使用Reflex构建现代Web应用的完全指南》这篇文章为大家深入介绍了Reflex框架的设计理念,技术特性,项目结构,核心API,实际开发流程以及与其他框架的对比和部署建议,感兴趣的小伙... 目录什么是 ReFlex?为什么选择 Reflex?安装与环境配置构建你的第一个应用核心概念解析组件

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue