微前端架构 之 应用之间样式隔离 (四)

1. 使用 CSS Modules 进行样式隔离

1. 安装必要的依赖
如果你使用 webpack 作为构建工具,你可能需要安装 css-loader 和 style-loader。如果你的项目使用 Create React App 或其他现代前端框架,这些可能已经内置了。

npm install --save-dev css-loader style-loader

2. 编写 CSS Modules 样式
在微前端应用的MyComponent.module.css文件中:

/* MyComponent.module.css */  
.root {  display: flex;  align-items: center;  justify-content: center;  height: 100px;  background-color: #f0f0f0;  
}  .button {  padding: 10px 20px;  background-color: #007bff;  color: white;  border: none;  border-radius: 4px;  cursor: pointer;  
}

3. 在 React 组件中使用 CSS Modules
使用 styles.root 和 styles.button 而不是直接使用字符串 ‘root’ 和 ‘button’ 作为类名。CSS Modules 会自动为这些类名添加唯一的哈希值,以确保它们在每个微前端应用中都是唯一的。

// MyComponent.js  
import React from 'react';  
import styles from './MyComponent.module.css'; // 导入 CSS Modules  const MyComponent = () => (  <div className={styles.root}>  <button className={styles.button}>Click Me</button>  </div>  
);  export default MyComponent;

4. 配置 webpack(如果需要)

// webpack.config.js  
module.exports = {  // ...  module: {  rules: [  // ...  {  test: /\.css$/,  use: [  'style-loader',  {  loader: 'css-loader',  options: {  modules: true, // 启用 CSS Modules  // 可以添加其他选项,如 localIdentName、camelCase 等  },  },  ],  },  // ...  ],  },  // ...  
};

在主应用中,你可以像平常一样加载微前端应用。由于每个微前端应用都使用 CSS Modules 进行样式隔离,因此它们之间的样式不会相互干扰。

2. 使用 CSS 命名空间进行样式隔离

为每个应用定义一个唯一的命名空间。这可以通过在 CSS 选择器前添加特定的前缀来实现。
app-a 的 CSS

/* app-a.css */  
.app-a-root {  /* 应用 A 的根样式 */  
}  .app-a-root .button {  /* 应用 A 的按钮样式 */  
}

app-b 的 CSS

/* app-b.css */  
.app-b-root {  /* 应用 B 的根样式 */  
}  .app-b-root .button {  /* 应用 B 的按钮样式 */  
}

在应用中应用命名空间
app-a 的 HTML

//在实际应用中,你可能不需要在类名中重复根命名空间(如 .app-a-root-button)
<div class="app-a-root">  <button class="app-a-root-button">点击我(应用 A</button>  
</div>

加载和隔离 CSS

最后,确保每个应用的 CSS 只在其自己的作用域内加载和应用。这可以通过在微前端框架中实现特定的加载和卸载逻辑来实现,或者通过使用
Webpack 的 css-loader 和 style-loader(或类似的工具)的 modules 选项来实现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/15902.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springboot结合baomidou dynamic-datasource组件实现多数据源

dynamic-datasource组件实现多数据源 一、背景介绍二、 思路方案三、过程四、总结五、升华 一、背景介绍 博主最近研发的项目中由于业务需要&#xff0c;在项目中使用到多个数据源。使用到了baomidou的dynamic-datasource组件来实现访问不同的数据源。觉得挺有意思的也是进行了…

Redis事务(1)

什么是事务&#xff1f; Redis 的事务和 MySQL 的事务概念上是类似的. 都是把⼀系列操作绑定成⼀组. 让这⼀组能够批量执行。 但是注意体会 Redis 的事务和 MySQL 事务的区别: 弱化的原⼦性: redis 没有 “回滚机制”. 只能做到这些操作 “批量执⾏”. 不能做到 “⼀个失败就…

海外链游地铁跑酷全自动搬砖挂机掘金变现项目,号称单窗口一天收益30+(教程+工具)

一、项目概述 地铁跑酷海外版国外版自动搬砖挂机掘金项目是一款结合了地铁跑酷元素的在线游戏&#xff0c;为玩家提供一个全新的游戏体验&#xff0c;使得玩家可以轻松地进行游戏&#xff0c;无需手动操作&#xff0c;节省时间和精力。 二、游戏特点 1. 自动化操作&#xff1…

AI应用案例:影像报告智能辅助编辑系统

今天给大家介绍一个医疗行业的案例“影像报告智能辅助编辑系统”&#xff01;该案例已经在某三甲医院落地&#xff0c;模型准确度超过80%。 该项目上线后&#xff0c;保守估计&#xff0c;能为每位医生的每一张报告至少省下1分钟时间和2分钟的精力&#xff0c;20位初级医生&…

Django Web:搭建Websocket服务器(入门篇)

Django Web架构 搭建Websocket服务器&#xff08;1&#xff09; - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:htt…

如何在Windows 10上对硬盘进行碎片整理?这里提供步骤

随着时间的推移&#xff0c;由于文件系统中的碎片&#xff0c;硬盘驱动器可能会开始以较低的效率运行。为了加快驱动器的速度&#xff0c;你可以使用内置工具在Windows 10中对其进行碎片整理和优化。方法如下。 什么是碎片整理 随着时间的推移&#xff0c;组成文件的数据块&a…

Incremental Task and Motion Planning: A Constraint-Based Approach(翻译)

摘要——我们提出了一种新的任务和运动算法规划&#xff08;TMP&#xff09;&#xff0c;并讨论获得TMP的健壮解决方案所必需的需求和抽象。我们的迭代深化任务和运动规划&#xff08;IDTMP&#xff09;与类似的、最先进的、概率完全的规划器相比&#xff0c;该方法是概率完全的…

LeetCode热题100——矩阵

73.矩阵清零 题目 给定一个 *m* x *n* 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 示例 1&#xff1a; 输入&#xff1a;matrix [[1,1,1],[1,0,1],[1,1,1]] 输出&#xff1a;[[1,0,1],[0,0,0],[1,0,1]] 示例…

【Linux】端口映射

外部访问http://127.0.0.1&#xff08;默认端口80&#xff09; 实际访问http://127.0.0.1:8080 //添加规则 iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8080 //移除规则 iptables -t nat -L -nv --line-numbers iptables -t nat -D PREROUT…

HTML+CSS 玻璃按钮

效果演示 Code <!DOCTYPE html> <html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>玻璃按钮</title><li…

期权课程之第二节【买方和卖方的误区和区别】

期权和股票不一样&#xff0c;我们玩股票大部分情况我们只会做买方&#xff0c; 看涨多买点&#xff0c;看跌了减仓&#xff0c;或者直接离场&#xff0c;就算不看好的公司&#xff0c;一般也不会尝试卖空股票的操作&#xff0c;但是期权不一样&#xff0c;我们不仅能做买方还可…

设计模式 17 组合模式 Composite Pattern

设计模式 17 组合模式 Composite Pattern 1.定义 组合模式&#xff08;Composite Pattern&#xff09;&#xff0c;又叫部分整体模式&#xff0c;是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象&#xff0c;用来表示部分以及整体层次。这种类型的设…

window好用的网速工具

这是一个用于显示当前网速、CPU及内存利用率的桌面悬浮窗软件&#xff0c;并支持任务栏显示&#xff0c;支持更换皮肤。 github链接如下 https://github.com/zhongyang219/TrafficMonitor?tabreadme-ov-file

无人机飞手:ASFC无人机和航模爱好者证书详解

ASFC无人机和航模爱好者证书是由中国航空运动协会&#xff08;ASFC&#xff09;颁发的一种无人机操作资格认证。这种证书在无人机和航模爱好者群体中享有广泛的认可度&#xff0c;并被视为操作无人机的一种重要资质。 ASFC证书的定义和用途十分明确。它是民航局颁发的民用无人驾…

springboot3微服务下结合springsecurity的认证授权实现

1. 简介 在微服务架构中&#xff0c;系统被拆分成许多小型、独立的服务&#xff0c;每个服务负责一个功能模块。这种架构风格带来了一系列的优势&#xff0c;如服务的独立性、弹性、可伸缩性等。然而&#xff0c;它也带来了一些挑战&#xff0c;特别是在安全性方面。这时候就体…

【前端笔记】Vue项目报错Error: Cannot find module ‘webpack/lib/RuleSet‘

网上搜了下发现原因不止一种&#xff0c;这里仅记录本人遇到的原因和解决办法&#xff0c;仅供参考 原因&#xff1a;因为某种原因导致本地package.json中vue/cli与全局vue/cli版本不同导致冲突。再次提示&#xff0c;这是本人遇到的&#xff0c;可能和大家有所不同&#xff0c…

一张图片中有多个一样的目标物体,分别进行识别定位分割(Python实现)

需求&#xff1a; 一张图片中有多个目标物体&#xff0c;将多个目标物体进行识别分割定位 import cv2 import numpy as npdef show_photo(name,picture):cv2.imshow(name,picture)cv2.waitKey(0)cv2.destroyAllWindows()img_path r"test3.png" img cv2.imread(img…

关于微信小程序低功耗蓝牙ECharts实时刷新

最近搞了这方面的东西&#xff0c;是刚刚开始接触微信小程序&#xff0c;因为是刚刚开始接触蓝牙设备&#xff0c;所以这篇文章适合既不熟悉小程序&#xff0c;又不熟悉蓝牙的新手看。 项目要求是获取到蓝牙传输过来的数据&#xff0c;并显示成图表实时显示&#xff1b; 我看了…

转运机器人负载最高可达 1000kg,重复精度高达±5mm

转运机器人&#xff0c;内部搭载ICD系列核心控制器&#xff0c;拥有不同的移载平台&#xff0c;负载最高可达 1000kg;重复精度高达5mm;支持 Wi-Fi漫游&#xff0c;实现更稳健的网络数据交互;无轨化激光 SLAM 导航&#xff0c;配合 3D 避障相机等多传感器进行安全防护。转运器人…

java中使用jedis连接redis

4.java中使用jedis连接redis