应用开发

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

时间:2010-12-5 17:23:32  作者:域名   来源:数据库  查看:  评论:0
内容摘要:CSS 变量基础知识这是介绍 css 的基础语法,了解地可以直接跳过到实际 demo . 既然是变量,他跟 JS 的变量很像,分为 声明、使用、作用域 三块。声明变量 【通过 --连接变量名 】::r

CSS 变量基础知识

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

声明变量 【通过 --连接变量名 】::root {

--test: red;

}使用变量 【var(变量名)读取变量】:

.test {

color: var(--foo);

}作用域 优先级最高的用C雅选择器声明生效。适配 iphone x 刘海屏

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

如何适配这种屏幕,用C雅有2个步骤:

HTML 中指定 viewport-fit 为 cover,变量让页面充满全屏;CSS 中可用 env() 获取对应安全区域。代码

.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;

使用如下:

...

/* 修改颜色 */

.beidan {

--hairline-color: #e9e9e9;

}最后

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

copyright © 2025 powered by 益强资讯全景  滇ICP备2023006006号-31sitemap