实现 css 样式隔离的方法

样式隔离是一种在 Web 开发中常用的技术,用于确保组件或模块之间的样式不会相互影响,从而提高代码的可维护性和可重用性

  1. CSS Modules: CSS Modules 是一种将 CSS 文件转换成 JavaScript 模块的技术,其中每个 CSS 类都会被自动命名,从而避免了类名冲突。在使用 CSS Modules 时,每个组件都可以拥有自己的 CSS 文件,并且其中的类名只在当前组件中有效,不会影响其他组件。【每个css文件就相当于一个独立的模块,使用 import 导入】

  2. CSS-in-JS: CSS-in-JS 是一种将 CSS 写在 JavaScript 中的技术,其中使用了类似于 CSS Modules 的自动命名机制来确保样式的隔离性。常见的 CSS-in-JS 库包括 styled-components、Emotion 等。【需要使用一些库,react、vue等项目中都能用,但是 vue 中不如 react 中使用的多,参考

  3. Scoped CSS: Scoped CSS 是一种使用特殊的选择器或属性来限定样式的作用范围的技术。例如,在 Vue.js 中,可以使用 <style scoped> 标签来定义组件的样式,从而确保样式只在当前组件中生效。【参考

  4. Shadow DOM: Shadow DOM 是一种浏览器原生的技术,用于创建独立的 DOM 子树和样式范围。通过将组件的内容包裹在 Shadow DOM 中,可以确保组件内部的样式不会影响到外部的样式。Shadow DOM的作用:

    1. Shadow DOM(影子 DOM)是 Web 标准的一部分,它为 Web 开发者提供了一种创建独立的 DOM 子树和样式范围的机制

    2. 样式隔离: Shadow DOM 允许开发者在一个独立的 DOM 子树中定义样式,使得样式只对该子树内部生效,不会影响到外部文档或其他 DOM 元素。这样做可以避免全局样式污染和样式冲突的问题,提高了代码的可维护性和可重用性。

    3. 封装组件: 开发者可以使用 Shadow DOM 来封装复杂的组件,将组件的内部结构和样式隐藏起来,只暴露必要的接口和功能给外部使用。这样做可以有效地降低组件的耦合度,提高了组件的可组合性和可复用性。

    4. 模拟原生组件: Shadow DOM 具有类似于原生组件的特性,例如封闭的样式范围、封闭的事件处理机制等,使得开发者可以更轻松地创建自定义的原生组件或控件,提供更好的用户体验和交互效果。

    5. 插件化开发: 使用 Shadow DOM 可以实现插件化开发的方式,将插件的内容和样式封装在独立的 DOM 子树中,然后将其插入到文档中的任意位置,从而实现更灵活和可扩展的应用开发。

  5. BEM(Block Element Modifier): BEM 是一种命名约定,用于给 HTML 元素添加类名,从而限定样式的作用范围。通过遵循 BEM 命名约定,可以确保每个组件或模块的样式都是独立的。官网地址 参考这篇文章。

相关推荐
摇滚侠15 分钟前
css 设置边框
前端·css
星爷AG I37 分钟前
9-24 视觉叙事(AGI基础理论)
前端·人工智能
2501_9400078941 分钟前
Flutter for OpenHarmony三国杀攻略App实战 - 鸿蒙适配与打包发布
前端·flutter
css趣多多41 分钟前
跨域问题及Vue项目中本地/线上解决方法核心总结
前端
光影少年1 小时前
前端 AIGC
前端·aigc
启山智软1 小时前
供应链商城核心功能模块清单
java·前端·开源
徐同保1 小时前
Claude Code提示词案例(开发复杂动态路由详情页面)
前端
Σdoughty1 小时前
python第三次作业
开发语言·前端·python
白中白121381 小时前
Vue系列-2
前端·javascript·vue.js
CHU7290352 小时前
一番赏盲盒小程序前端功能:层级乐趣与便捷服务的双向赋能
前端·小程序