CSS中的计算函数

前言


🎯大家好我是一溪风月一名普普通通的前端开发,做前端两年多了,但是自己反思了一下,在这两年多的时间,在对技术的追寻上一直都是追求新与多在这个道路上往往忽略了前端最本质的东西,那就是前端究竟在做什么,前端的价值和意义在什么地方,前端的基础,经过自己的思考决定从头学习下前端的知识,让自己沉下心来查漏补缺,放弃追逐新东西,寻找自己,了解自己。

一.什么是CSS中的函数?


😊我们知道在CSS中有很多类似于rgb rgba rotate scale等等,其实这些就是CSS中的函数,就像rgb在颜色中应该没有一个颜色叫做rgb吧,其实这些都是CSS提供给我们的函数供我们传入一些数据让引擎来进行计算,返回给我们具体的颜色值,这样做的好处是比较灵活,今天我们就在这些内容的基础上学习一些CSS中常见且好用的CSS计算函数。

  1. var:使用CSS定义的变量。
  2. calc:计算CSS的值,通常用于计算元素的大小和位置。

二.var函数的使用


🤡我们在日常的开发中可能会遇到这样的场景,在页面中有很多相同的颜色值,这样的话我们就需要一次一次的去复制粘贴对应的颜色,但是可能有时候我们需要直接把这些相同的颜色全部更换成某个颜色,那么我们就老老实实的一个一个的修改,会很多麻烦,也可能容易出现错误,所以CSS就提供了var函数,用来使用CSS定义的变量,那么CSS是如何定义变量的哪?

😶‍🌫️CSS定义变量的方式如下,需要在定义的变量名前面加上--表示这是自定义的变量。

css 复制代码
--main-color:red

🎯我们使用自定义变量的方法很简单,就是使用我们所说的var函数来使用它。

css 复制代码
:root {
  --main-color: red;
}
/* :root 选中的就是html标签 */

.main-box {
  color: var(--main-color);
}

🔔变量的定义位置建议定义在html当然我们可以使用:root来代替,因为定义变量的使用规则就是只有它的子节点可以使用,所以一般我们都会定义在全局中,这点跟JS中的作用域比较相似,可以类比理解。

三.calc函数的使用


👽calc的使用场景是进行一些简单的数学运算,假如有一个大盒子中套了两个小盒子,一个盒子宽度固定,我们想要另一个盒子将剩余的内容占满,其实这个需求很简单哪,我们直接使用flex布局就可以了,但是如果我们不使用这个布局的方式该如何进行实现哪?

css 复制代码
.main-box {
  width: 700px;
  height: 100px;
  background-color: aquamarine;
}

.main-box>div:first-child {
  display: inline-block;
  width: 300px;
  height: 100%;
  background-color: antiquewhite;
}

.main-box>div:last-child {
  display: inline-block;
  width: calc(700px - 400px);
  height: 100%;
  background-color: blueviolet;
}

🔔注意:当我们在进行calc的计算的时候运算符左右两边需要空格,否则会没有反应。


相关推荐
天人合一peng1 小时前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
方也_arkling2 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐2 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
web打印社区2 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO3 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu121383 小时前
Vuex介绍
前端·javascript·vue.js
We་ct3 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949480064 小时前
【无标题】
开发语言·前端·javascript
css趣多多4 小时前
Vue过滤器
前端·javascript·vue.js
理人综艺好会4 小时前
Web学习之用户认证
前端·学习