五大CSS 样式继承

效果

一、使用公共样式类@extend继承

适用于小型项目,样式简单,共享样式局部复用时适用。

/* 公共样式 */
.stat-common {
  font-family: "Arial";
  font-weight: 400;
  color: #fff;
  text-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.stat {
  .stat-title {
    @extend .stat-common; /* 复用公共样式 */
    font-size: 25px;
  }

  .stat-description {
    @extend .stat-common; /* 复用公共样式 */
    font-size: 40px;
  }
}

二、使用父级继承

适用于当子元素都共享同样的公共样式,且都位于同一个父级容器内。

.stat {
  font-family: "Arial";
  font-weight: 400;
  color: #fff;
  text-shadow: 0 0 6px rgba(16, 173, 255, 0.91);

  .stat-title{
    font-size: 25px;
  }

  .stat-description{
    font-size: 40px;
  }
}

三、使用 CSS 变量

适用于公共样式需要在多个组件之间共享,甚至跨页面使用。

:root {
  --font-family: "Arial";
  --font-weight: 400;
  --text-color: #fff;
  --text-shadow: 0 0 6px rgba(16, 173, 255, 0.91);
}

.stat {
  font-family: var(--font-family);
  font-weight: var(--font-weight);
  color: var(--text-color);
  text-shadow: var(--text-shadow);

  .stat-title{
    font-size: 25px;
  }

  .stat-description{
    font-size: 40px;
  }
}

四、使用混合宏(Mixin,适用于 Sass/LESS)

适用于需要高度复用的样式,并且已经使用 Sass/LESS 等 CSS 预处理器。

@mixin stat-common {
  font-family: "Arial";
  font-weight: 400;
  color: #fff;
  text-shadow: 0 0 6px rgba(16, 173, 255, 0.91);
}

.stat {
  .stat-title{
    @include stat-common;
    font-size: 25px;
  }

  .stat-description {
    @include stat-common;
    font-size: 40px;
  }
}

五、使用 Utility 类(BEM 方法论扩展)

适用于公共样式需要在多个类之间自由组合和复用。

.u-stat-common {
  font-family: "Arial";
  font-weight: 400;
  color: #fff;
  text-shadow: 0 0 6px rgba(16, 173, 255, 0.91);
}

.stat-title{
  ime-mode: u-stat-common;
  font-size: 25px;
}

.stat-description{
  ime-mode: u-stat-common;
  font-size: 40px;
}

若不使用CSS Modules,可以直接使用组合类:

  <div class="stat">
    <div class="stat-title u-stat-common">标题</div>
    <div class="stat-description u-stat-common">描述</div>
  </div>

六、总结

方法适用场景优点局限性
@extend小型项目,样式简单,共享样式局部复用时适用简洁,直接复用样式耦合,可能导致选择器冗余
父级继承简单需求,子元素同属一个父级,所有元素共享公共样式简单直观子元素必须在同一父级内,缺乏灵活性
CSS 变量需要动态更新样式(如主题切换)或跨组件复用场景动态可变,跨组件复用,支持主题切换不支持旧版浏览器,复杂样式不易管理
混合宏 (Mixin)参数化高复用,样式中有细微差异,或公共样式需要配置参数灵活可控,支持参数样式量多时会增加生成 CSS 的体积
Utility 类 (BEM 扩展)组件高度模块化,样式需要跨组件复用高度复用,与结构解耦命名规则需要统一,语义化可能不足


追更:

:root 伪类

  1.  是一个 CSS 伪类,它匹配文档的根元素。在 HTML 文档中,根元素就是 <html>
  2. 使用 :root 定义的 CSS 变量在整个文档中都是全局可用的。
:root {
  --el-color-primary: #fff;
  // css自定义属性,以 -- 开头,表示自定义属性
  /**
  --el-color-primary 被设置为 #fff(白色)
  --el-color-primary 的地方都会应用这个颜色值
  如果你在其他地方已经定义了 --el-color-primary,这里的定义会覆盖之前的值。
  */ 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端熊猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值