前言
开发过程中,写元素的长宽,往往是父元素设置了自适应高度100%,而其子元素的高度应该设置为父元素高度减去10px。在自适应高度100%的作用下,无法明确固定子元素的高度,故每次页面渲染都需要进行高度计算。把这种计算放到js里面,貌似有点非常low的感觉。针对于这种需求,css提供了calc()函数,专门把计算过程写在css样式里面。
实例
使用 calc() 函数计算 <div> 元素的宽度:
#div1 {
position: absolute;
left: 50px;
width: calc(100% - 100px);
border: 1px solid black;
background-color: yellow;
padding: 5px;
text-align: center;
}
定义与用法
calc() 函数用于动态计算长度值。
- 需要注意的是,运算符前后都需要保留一个空格,例如:width: calc(100% - 10px);
- 任何长度值都可以使用calc()函数进行计算;
- calc()函数支持 "+", "-", "*", "/" 运算;
- calc()函数使用标准的数学运算优先级规则;
支持版本:CSS3
浏览器支持
表格中的数字表示支持该函数的第一个浏览器版本号。
"webkit" 或 "moz" 或 "o" 指定的数字为支持该函数的第一个版本号前缀。
CSS 语法
calc(expression)
expression必须,一个数学表达式,结果将采用运算后的返回值。