【CSS笔记】— 使用calc()计算宽高(vw/vh)

【CSS笔记】— 使用calc()计算宽高(vw/vh)

calc()是什么?

简单来讲就是CSS3中新增的一个函数,calculate(计算)的缩写。用于动态计算宽/高,你可使用calc()给元素的各个属性设置值【margin、border、padding、font-size】等,web

calc()语法

calc的语法就是简单的四则运算,浏览器

  1. 使用“+”、“-”、“*” 和 “/”四则运算;
  2. 可使用百分比、px、em、rem等单位;
  3. 能够混合使用各类单位进行计算;
  4. 表达式中有“+”和“-”时,其先后必需要有空格,如"width: calc(12%+5em)"这种没有空格的写法是错误的;
  5. 表达式中有“*”和“/”时,其先后能够没有空格,但建议留有空格。

calc()的用途

主要用于计算不肯定值,例如一个外边距为10px,宽度为100%的元素,这种状况咱们怎么设置呢?若是设置了bash

width: 100%;
margin: 10px;
复制代码

你能够看出这个box已经溢出了,那么怎么解决呢?就能够用calc函数了。markdown

width: 800px;
width: calc(100% - (10 *2)px);
margin: 10px;
复制代码

vw和vh是什么?

vw、vh、vmin、vmax是一种视窗单位,也是相对单位。它相对的不是父节点或者页面的根节点。而是由视窗(Viewport)大小来决定的,单位 1,表明相似于 1%。 视窗(Viewport)是你的浏览器实际显示内容的区域—,换句话说是你的不包括工具栏和按钮的网页浏览器。函数

具体描述以下:工具

  1. vw:视窗宽度的百分比(1vw 表明视窗的宽度为 1%)
  2. vh:视窗高度的百分比
  3. vmin:取当前Vw和Vh中较小的那一个值
  4. vmax:取当前Vw和Vh中较大的那一个值

vw、vh 与 % 百分比的区别

(1)% 是相对于父元素的大小设定的比率,vw、vh 是视窗大小决定的。 (2)vw、vh 优点在于可以直接获取高度,而用 % 在没有设置 body 高度的状况下,是没法正确得到可视区域的高度的,因此这是挺不错的优点。spa

calc和vh/vw结合使用

上面咱们使用%结合calc使用能够实现想要的效果,为何要引入vw和vh呢?上面说%和vw,vh的区别中,% 在没有设置 body 高度的状况下,是没法正确得到可视区域的高度的。code

calc + vw 计算宽度
width: 800px; /* fallback for b*/
width: -moz-calc(100vw - (2 * 10)px);
width: -webkit-calc(100vw -(2 * 10)px);
width: calc(100vw - (2 * 10)px);
复制代码
calc + vh 计算高度
height: 800px;
height: -moz-calc(100vh - (2 * 10)px);
height: -webkit-calc(100vh - (2 * 10)px);
height: calc(100vh - (2 * 10)px);
复制代码
相关文章
相关标签/搜索