我刚刚了解了一个新的和不常见的CSS单元。Vh和vw分别测量视口高度和宽度的百分比。

我从Stack Overflow中看到了这个问题,但它让单位看起来更加相似。

vw和vh单位是如何工作的

答案明确地说

Vw和vh是窗宽和窗高的百分比, 分别为:100vw为宽度的100%,80vw为宽度的80%,等等。

这似乎与%单位完全相同,后者更常见。

在开发人员工具中,我尝试将值从vw/vh更改为%,反之亦然,得到了相同的结果。

这两者之间有什么区别吗?如果不是,为什么这些新单位被引入到CSS3?


当前回答

%和vw之间的差异最类似于em和rem之间的差异。%长度相对于本地上下文(包含元素)的宽度,而vw长度相对于浏览器窗口的全宽度。

其他回答

vw (view-width)和vh (view-height)单位与视口大小有关,其中100vw或vh是视口宽度/高度的100%。

例如, 如果一个视口宽为1600px,并且你指定某个值为2vw,这将相当于视口宽度的2%,或32px。

% unit总是基于当前元素的父元素宽度

有一个不一定被提出的差异。100vw包含滚动条宽度,100%不包含滚动条宽度。这是一个很小的区别,但在做设计时很重要。

整个视口宽度的百分比。10vw将解析为当前视口宽度的10%,或者在480px宽的手机上解析为48px。%与vw之间的差异与em与rem之间的差异最为相似。

%长度相对于本地上下文(包含元素)的宽度,而vw长度相对于浏览器窗口的全宽度。

我知道这个问题很老了,@Josh Beam提到了最大的区别,但还有一个问题:

Suppose you have a <div>, direct child of <body> that you want filling the whole viewport, so you use width: 100vw; height: 100vh;. It all works just the same as width: 100%; height: 100vh; until you add more content and a vertical scrollbar shows up. Since the vw account for the scrollbar as part of the viewport, width: 100vw; will be slightly bigger than width: 100%;. This little difference ends up adding a horizontal scrollbar (required for the user to see that little extra width) and by consequence, the height would also be a little different on both cases.

在决定使用哪一个时,即使父元素大小与文档视口大小相同,也必须考虑到这一点。

例子:

使用宽度:100大众;

.fullviewport { 宽度:100大众; 身高:100 vh; 背景颜色:红色; } .extracontent { 宽度:100大众; 高度:20 vh; 背景颜色:蓝色; } < html > 身体< > < div class = " fullviewport " > < / div > < div class = " extracontent " > < / div > 身体< / > < / html >

使用宽度:100%;:

.fullviewport { 宽度:100%; 身高:100 vh; 背景颜色:红色; } .extracontent { 宽度:100%; 高度:20 vh; 背景颜色:蓝色; } < html > 身体< > < div class = " fullviewport " > < / div > < div class = " extracontent " > < / div > 身体< / > < / html >

谢谢你的回答和代码示例,@IanC。这对我帮助很大。澄清一下:我相信你说的“边栏”指的是“滚动条”。

下面是一些关于视口单元计算滚动条的相关讨论,我认为这些讨论也很有帮助:

为什么vw包含滚动条作为视口的一部分? 当存在垂直滚动条时,使用100vw会导致水平裁剪 防止100vw产生水平滚动 宽度:100%和宽度:100vw?

vw, vh, vmin, vmax单位(“视口百分比长度”)的W3C规范说“任何滚动条都假定不存在”。

显然,Firefox从100vw中减去了滚动条宽度,正如@Nolonar在width: 100%和width:100vw之间的差异上的评论?他引用了“我可以使用吗?”

可能与规范(?)相矛盾的是,除了Firefox之外的所有浏览器目前都“错误地”认为100vw是包括垂直滚动条在内的整个页面宽度。