​妙用 CSS 变量,让你的代码更优雅

css 变量基础知识

这是介绍 css 的基础语法,了解地可以直接跳过到实际 demo . 既然是变量,他跟 JS 的变量很像,分为 声明、使用、作用域 三块。

  1. 声明变量 【通过 --连接变量名 】

:root {
  --test: red;
}
  1. 使用变量 【var(变量名)读取变量】

.test {
  color: var(--foo);
}
  1. 作用域 优先级最高的选择器声明生效。

适配 iphone x 刘海屏

Apple 在发布 iPhone X 后引入了一个新概念:安全区域(Safe Area),安全区域指屏幕内不受圆角、刘海、底部小黑条等元素影响的可视窗口。如下图:

554b3b760407c6f091015814edcf5f93.png

如何适配这种屏幕,有2个步骤

  • HTML 中指定 viewport-fit 为 cover,让页面充满全屏;

  • CSS 中可用 env() 获取对应安全区域。

<meta name="viewport" content="viewport-fit=cover">
.safe-area {
  padding-top: env(safe-area-inset-top);
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
  padding-bottom: env(safe-area-inset-bottom);
}

由于兼容性,iOS 11 用的是 constant(),但从 iOS 11.2 开始改用 env()。如果用 CSS 变量来实现(ChatUI 源码实现),感觉挺好的,如下:

:root {
  --safe-top: 0px;
  --safe-bottom: 0px;
}

@supports (top: constant(safe-area-inset-top)) {
  :root {
    --safe-top: constant(safe-area-inset-top);
    --safe-bottom: constant(safe-area-inset-bottom);
  }
}

@supports (top: env(safe-area-inset-top)) {
  :root {
    --safe-top: env(safe-area-inset-top);
    --safe-bottom: env(safe-area-inset-bottom);
  }
}

代码逻辑如下:

  1. 先定义 --safe-top、--safe-bottom 2个 CSS 自定义变量;

  2. 通过 @supports 来判断当前浏览器是否支持 constant() / env() ;

  3. 在支持的情况下,把取到的值赋给 CSS 自定义变量。然后在需要使用的地方就可以这样用了:

.navbar {
  padding-top: var(--safe-top);
}

body {
  height: calc(100vh - var(--safe-bottom));
}

实现 1px 边框

同样的,以往的代码我们可能是使用 scss 语法来实现, 会实现一段比较复杂的传参等。

@mixin retina-border($top: 0, $right: 0, $bottom: 0, $left: 0, $cor: #000000) {
  
}
// 调用
@include retina-border();

如果使用了 css 变量,代码变得很简单,也更灵活

.hairline {
  position: relative;
}

.hairline::after {
  content: ' ';
  position: absolute;
  width: 200%;
  height: 200%;
  border: 0 solid var(--hairline-color, #f2f4f5);
  border-width: var(--hairline-width, 1px);
  border-radius: calc(var(--hairline-radius) * 2);
  pointer-events: none;
  transform: scale(0.5);
  transform-origin: 0 0;
}

使用如下:

<div class="beidan hairline">...</div>

/* 修改颜色 */
.beidan {
  --hairline-color: #e9e9e9;
}

最后

css 变量可以让你的代码更灵活,更优雅,可以看到各大开源库全部都拥抱 css 变量了,是时候可以抛弃 scss 了😄

内推社群

我组建了一个氛围特别好的阿里内推社群,如果你对加入阿里感兴趣的话(后续有计划也可以),我们可以一起进行面试相关的答疑、聊聊面试的故事、并且在你准备好的时候随时帮你内推。下方加 peen 好友回复「面试」即可。

已内推7+成功拿offer,2+入职,快快来吧~期待你的加入

301632aadfa8d41f9af8a1a82e6006ee.png


bb55f902f0378ad17c4697561d4b8896.gif

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值