实现 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 命名约定,可以确保每个组件或模块的样式都是独立的。官网地址 参考这篇文章。

相关推荐
轻口味26 分钟前
【每日学点鸿蒙知识】AVCodec、SmartPerf工具、web组件加载、监听键盘的显示隐藏、Asset Store Kit
前端·华为·harmonyos
alikami28 分钟前
【若依】用 post 请求传 json 格式的数据下载文件
前端·javascript·json
吃杠碰小鸡1 小时前
lodash常用函数
前端·javascript
emoji1111111 小时前
前端对页面数据进行缓存
开发语言·前端·javascript
泰伦闲鱼1 小时前
nestjs:GET REQUEST 缓存问题
服务器·前端·缓存·node.js·nestjs
m0_748250031 小时前
Web 第一次作业 初探html 使用VSCode工具开发
前端·html
一个处女座的程序猿O(∩_∩)O1 小时前
vue3 如何使用 mounted
前端·javascript·vue.js
m0_748235951 小时前
web复习(三)
前端
机器视觉李小白1 小时前
使用 HTML 和 CSS 实现绚丽的节日烟花效果
css·html·烟花·节日·节日祝福
AiFlutter2 小时前
Flutter-底部分享弹窗(showModalBottomSheet)
java·前端·flutter