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

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

CSS 变量基础知识

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

  • 声明变量 【通过 --连接变量名 】:
:root {
--test: red;
}
  • 使用变量 【var(变量名)读取变量】:

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

适配 iphone x 刘海屏

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

如何适配这种屏幕,有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);
}
}

代码逻辑如下:

  • 先定义 --safe-top、--safe-bottom 2个 CSS 自定义变量;
  • 通过 @supports 来判断当前浏览器是否支持 constant() / env() ;
  • 在支持的情况下,把取到的值赋给 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
相关推荐

2020-04-03 14:55:39

Python 代码编程

2020-07-24 15:40:51

CSS前端代码

2022-04-10 10:41:17

ESLint异步代码

2022-03-11 12:14:43

CSS代码前端

2023-11-23 13:50:00

Python代码

2019-09-29 16:17:25

Java代码性能编程语言

2017-09-27 16:09:29

代码

2023-07-10 09:39:02

lambdaPython语言

2022-12-26 07:47:37

JDK8函数式接口

2022-11-18 08:32:23

spring参数解析器

2018-07-12 14:20:33

SQLSQL查询编写

2024-02-23 08:57:42

Python设计模式编程语言

2024-02-07 01:47:47

atexit模块程序

2022-09-19 15:02:24

C语言

2021-01-14 09:59:07

JS代码编码

2021-09-22 11:05:19

JS代码前端

2021-12-07 08:16:34

React 前端 组件

2019-11-25 10:20:54

CSS代码javascript

2022-05-13 08:48:50

React组件TypeScrip

2023-12-21 10:26:30

​​Prettier
点赞
收藏

51CTO技术栈公众号