css3 vh单位使用

Css3和 html5发布已经过了5年之久,做为一个码农,其实里面新增加的标签,有些根本就不知道,更别说性能,这久再弄移动页面的时候,为了某种效果,我在查看网页的源代码的时候,我看到min-height:calc(100vh + 22px)
纳尼。。。,这个是什么写法,可以这种写?
结果百度了一下,真是惭愧啊!写了这么多年!不知道还可以这种写

Vw:相对于视框的宽度:视框宽度是100Vw
Vh:相对于视框的高度:视框高度是100Vh

“视区”所指为浏览器内部的可视区域大小,即window.innerWidth/window.innerHeight大小,不包含任务栏标题栏以及底部工具栏的浏览器区域大小

视区单位的兼容性:浏览器(https://caniuse.com/#search=vh)

css3 vh单位使用_第1张图片

相对现在主流的浏览器,视区的单位还是能够满足现在的需求,特别是在移动端上。

但是在写单位的时候在前面还有一个calc,这个又拿来做什么呢?
calc是英文单词calculate(计算)的缩写,是css3的一个新增的功能,用来指定元素的长度。比如说,你可以使用calc()给元素的border、margin、pading、font-size和width等属性设置动态值。为何说是动态值呢?因为我们使用的表达式来得到的值。不过calc()最大的好处就是用在流体布局上,可以通过calc()计算得到元素的宽度。

calc同时还可以进行运算的方式:
需要注意的是,运算符前后都需要保留一个空格,例如:width: calc(100% - 10px);
任何长度值都可以使用calc()函数进行计算;
calc()函数支持 “+”, “-“, “*”, “/” 运算;
calc()函数使用标准的数学运算优先级规则;
calc(100vh - 10px)  表示整个浏览器窗口高度减去10px的大小
calc(100vw - 10px)   表示整个浏览器窗口宽度减去10px的大小

css3 vh单位使用_第2张图片

这样我们在写移动端,不好确定固定值的时候,就比较方便,一些特殊的布局就比较好编写。使用下来也比较方便,相对宽度的最大和最小的设置,height:calc(100vh)的写法确实很方便,在弄移动端的侧栏时候,我需要一个背景,在设置这个背景的时候height:100%总是存在一些问题,如果是js 去获取手机的视图高度,感觉代码太多,用来下height:calc(100vh)就能解决这个问题。现对于100%的写法,我觉得视区单位更加好用。网上也又很多案例,喜欢的朋友可以多了解下。

你可能感兴趣的:(网站布局效果)