解决qiankun微前端Vue2+Element-ui主应用跳转到Vue3+Element-plus子应用样式冲突问题

一、前言

随着Vue3技术栈逐渐成熟,近期子应用新项目开始使用Vue3+vite+Element-plus技术栈,但之前子应用及主应用都是用Vue2+Element-ui+webpack技术栈,那么从主应用入口跳转到Vue3子应用存在样式冲突(主要是element-ui与element-plus这两套UI存在相同的类)。

二、解决Vue2主应用与Vue3子应用样式冲突方法(推荐使用第二种)

第一种、主应用上修改

在开启qiankun,即start()时,开启sandbox;按官网设置experimentalStyleIsolation: true,并没有达到预期效果,而设置strictStyleIsolation: true,有效果但整个样式都变化了,需要改动较大。

js 复制代码
 // 启动 qiankun
  start({
     prefetch: false, // 取消预加载
     sandbox: {
     // strictStyleIsolation: true, // 若需 Shadow DOM 隔离可设为 true
      experimentalStyleIsolation: true // 推荐开启,兼容性好
     }
   })

第二种、Vue3子应用修改------修改 Element Plus 命名空间ep(推荐)

完成以下步骤后,子应用 Element Plus 的类名会从 el-button 变为 ep-button,从而避免与主应用冲突。

1、修改根组件

子应用App.vue 中,使用 ElConfigProvider 组件设置新的命名空间,例如 ep

html 复制代码
<!-- 子应用 App.vue -->
<template>
  <el-config-provider namespace="ep">
    <router-view />
  </el-config-provider>
</template>

子应用main.ts 中,注册Element-plus 组件设置namespace(新的命名空间),例如 ep

js 复制代码
const instance = createApp(App);
 // 注册ElementPlus
  instance.use(ElementPlus, {
    locale, // 语言设置
    namespace: "ep"
  });

2、配置 SCSS 变量

子应用项目中,创建一个 SCSS 文件(如 src/styles/element/index.scss),用于定义新的命名空间。

css 复制代码
@forward 'element-plus/theme-chalk/src/mixins/config.scss' with (
  $namespace: 'ep'
);

3、配置构建工具,将上述 SCSS 文件全局引入。

1、Webpack:在 vue.config.js 中,配置 sass-loader
js 复制代码
// 子应用 vue.config.js
css: {
   loaderOptions: {
     scss: {
       additionalData: `@use "@/styles/element/index.scss" as *;`
     }
   }
 }
2、Vite:在 vite.config.js 中,配置 sass-loader
js 复制代码
css: {
   preprocessorOptions: {
      scss: {
        additionalData: `@use "@/styles/element/index.scss" as *;`
      }
    }
  },

4、修改入口文件(子应用 main.js 中需要引入 Element PlusSCSS 源文件),而不是编译后的 CSS,这样命名空间配置才会生效。(关键点)

js 复制代码
// main.ts
import ElementPlus from "element-plus";
// 注释掉这行
// import "element-plus/dist/index.css";
// 改为引入 SCSS 源文件
import "element-plus/theme-chalk/src/index.scss";
// element dark scss
// 注释掉这行
// import "element-plus/theme-chalk/dark/css-vars.css";
// 改为引入 SCSS 源文件
import "element-plus/theme-chalk/src/dark/css-vars.scss";

相关文章

基于ElementUi再次封装基础组件文档


vue3+ts基于Element-plus再次封装基础组件文档

相关推荐
rADu REME2 分钟前
SpringBoot + vue 管理系统
vue.js·spring boot·后端
被考核重击1 小时前
Vue响应式原理(下)
前端·javascript·vue.js
前端摸鱼匠12 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
Python私教1 天前
Pure-Admin-Thin 深度解析:完整版和精简版到底怎么选?
vue.js·人工智能·开源
ayqy贾杰1 天前
Cursor SDK发布!开发者可直接搬走其内核
前端·vue.js·面试
李白的天不白1 天前
vue 数据格式问题
前端·vue.js·windows
小白蒋博客1 天前
【ai开发段永平投资理财的知识图谱网站】第一天:搭 Vite + Vue 项目,跑通 Hello World
vue.js·人工智能·trae
@yanyu6661 天前
登录注册功能-明文
vue.js·springboot
滕青山2 天前
在线PDF拆分工具核心JS实现
前端·javascript·vue.js
光影少年2 天前
前端在页面渲染优化和组件优化经验?
前端·vue.js·react.js·前端框架