CSS3运算 calc()函数是怎么实现计算
CSS3 的 calc() 函数允许我们在属性值中执行数学计算操作。例如,我们可以使用 calc() 指定一个元素宽的固定像素值为多个数值的和。
.foo {
width: calc(100px + 50px);
}
为什么是 calc()
如果你使用过 CSS预处理器,比如 SASS,以上示例你或许碰到过。
.foo {
width: 100px + 50px;
}// Or using SASS variables
$width-one: 100px;
$width-two: 50px;
.bar {
width: $width-one + $width-two;
}
然而,calc() 函数提供了更好的解决方案。首先,我们能够组合不同的单元。特别是,我们可以混合计算绝对单元(比如百分比与视口单元)与相对单元(比如像素)。例如,我们可以创造一个表达式,用一个百分比减掉一个像素值。
.foo {
width: calc(100% - 50px);
}
本例中,.foo 元素总是小于它父元素宽度 50px。 第二,使用 calc(),计算值是表达式它自己,而非表达式的结果。当使用 CSS 预处理器做数学运算时,给定值为表达式的结果。
// Value specified in SCSS
.foo {
width: 100px + 50px;
}// Compiled CSS and computed value in browser
.foo {
width: 150px;
}
然而,浏览器解析的 calc() 的值为真实的 calc() 表达式。
// Value specified in CSS
.foo {
width: calc(100% - 50px);
}// Computed value in browser
.foo {
width: calc(100% - 50px);
}
这意味着浏览器中的值可以更加灵活,能够响应视口的改变。我们能够给元素设定一个高度为视口的高度减去一个绝对值,它将随视口的改变进行调节。
使用 calc()
calc() 函数可以用来对数值属性执行四则运算。比如,& lt;length>,& lt;frequency>,& lt;angle>,& lt;time>,& lt;number> 或者 & lt; integer 数据类型 这里有一些示例:
.foo {
width: calc(50vmax + 3rem);padding: calc(1vw + 1em);transform: rotate( calc(1turn + 28deg) );background: hsl(100, calc(3 * 20%), 40%);font-size: calc(50vw / 3);
}
calc() 函数可以用来对数值属性执行四则运算。比如
.foo {
width: calc( 100% / calc(100px * 2) );
}
函数的计算值如下所示:
.foo {
width: calc( 100% / (100px * 2) );
}