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

更新日期: 2022-03-08 阅读: 1.9k 标签: 变量

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 了。

作者:前端加加 ,链接:https://mp.weixin.qq.com/s/ILic8bdT0s044_SNCKpW2Q

本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://fly63.com/article/detial/11243

相关推荐

vue定义全局变量

VUE.js 中涉及到JS全局变量:全局变量专用模块得引入、全局变量模块挂载到Vue.prototype、使用VUEX存储状态值、使用window存储变量

let与var的区别,为什么要用let?

var是全局声明,let是块级作用的,只适用于当前代码块;var变量会发生变量提升,let则不会进行变量提升;var 会造成重复赋值,循环里的赋值可能会造成变量泄露至全局

php中的$_REQUEST超全局变量

PHP $_REQUEST是用于收集HTML表单提交的数据,PHP $_REQUEST属于PHP的超级全局变量。以下实例显示了一个输入字段(input)及提交按钮(submit)的表单(form)

从.env文件中为Node.js加载环境变量

使用环境变量是配置 Node.js 程序的好方法。而且许多包或模块可以基于不同的 NODE_ENV 变量的值表现出不同的行为。存储环境变量的一种方法是将它们放在 .env 文件中。这些文件允许你指定各种环境变量及其相应的值。

在vue中实现了在样式里使用js变量的方法

在使用vue开发时,经常会封装很多的组件方便复用,那么难免就有写样式相关组件,比如需要使用时传入颜色、高度等样式参数。

js 交换变量值的方法总汇

这篇文章总结七种办法来交换a和b的变量值 。最最最简单的办法就是使用一个临时变量了 ,最后我的方案是利用了ES6的解构赋值语法 ,它允许我们提取数组和对象的值,对变量进行赋值

理解var let const区别

JavaScript中var、let、const区别?js中let和const都是es5版本新的命名规范,在此之前定定义一个变量只能用var。我们可以把let和const看做是为了弥补var的一些不足而新设计出来的

css自定义变量_初次接触CSS变量

本文的目的主要是展示CSS变量是如何工作的。随着Web应用程序变得越来越大,CSS变得越来越大,越来越多,而且很多时候都很乱,在良好的上下文中使用CSS变量,为您提供重用和轻松更改重复出现的CSS属性的机制。

Node常用的全局变量与 Inspect 调试

在 Node 中常用的全局方法有 CommonJS、Buffer、process、console、timer 等,这些方法不需要 require引入 API 就可以直接使用。如果希望有属性或方法可以“全局使用”,那就将它挂载在 Node 的global对象上:

css变量_原生css 中变量的使用

原生css 中变量的使用,这个重要的 CSS 新功能,所有主要浏览器已经都支持了。本文全面介绍如何使用它,你会发现原生 CSS 从此变得异常强大。声明变量的时候,变量名前面要加两根连词线(--),var()函数用于读取变量。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!