您现在的位置是:网站首页> 编程资料编程资料

CSS Viewport 单位 实现快速布局CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题

2023-10-17 386人已围观

简介 这篇文章主要介绍了使CSS Viewport 单位 实现快速布局的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

**CSS Viewport units(视口单位)**在过去几年已经出现了,随着时间的推移,越来越多的开发人员开始使用它们。它们的好处在于为我们提供了一种不需要使用J avaScript 就能以动态的方式调整大小的方法。而且,如果它失效,也有很多备用方案。

在本文中,我们将学习 CSS Viewport units(视口单位)以及如何使用它们,并用列举一些常见问题及其解决方案和用例,让我们开始吧。

简介

根据CSS规范,视口百分比单位相对于初始包含块的大小,它是web页面的根元素。

视口单位为:vwvhvminvmax

vw单位表示根元素宽度的百分比。1vw等于视口宽度的1%

视口宽度

vw单位表示根元素宽度的百分比,1vw等于视口宽度的1%

假设我们有一个元素与以下CSS:

 .element { width: 50vw; }

当视口宽度为500px时,50vw计算如下

 width = 500*50% = 250px

视口高度

vh单位表示根元素高度的百分比,一个vh等于视口高度的1%

我们有一个元素与以下CSS:

 .element { height: 50vh; }

当视口高度为290px时,70vh计算如下:

 height = 290*70% = 202px

大家都说简历没项目写,我就帮大家找了一个项目,还附赠【搭建教程】。

Vmin 单位

vmin表示视口的宽度和高度中的较小值,也就是vwvh 中的较小值。如果视口宽度大于其高度,则将根据高度计算该值。

我们以下面的例子为例。

我们有一个横屏手机,其中有一个元素具有vmin单元。在这种情况下,值将根据视口高度计算,因为它小于宽度。

 .element { padding-top: 10vmin; padding-bottom: 10vmin; }

这是vmin的计算方式:

正如你所猜测的,计算结果如下所示

 padding-top = (10% of height) = 10% * 164 = 16.4px padding-bottom = (10% of height) = 10% * 164 = 16.4px

Vmax 单位

vmaxvmin相反,该值是vwvh 中的较大值。

我们以下面的例子为例。

 .element { padding-top: 10vmax; padding-bottom: 10vmax; }

计算结果如下:

 padding-top = (10% of width) = 10% * 350 = 35px padding-bottom = (10% of width) = 10% * 350 = 35p

视口单位与百分比有何不同?

视口单位基于页面的根元素,而百分比则基于它们所在的容器。因此,它们彼此不同,但各自都有各自的用处。

视口单位的用例字体大小

CSS 视口单位非常适合响应式排版。例如,我们可以将以下内容用作文章标题:

 .title { font-size: 5vw; }

标题的font-size将根据视口宽度增加或缩小。就像提供的字体大小是视口宽度的5%一样。但是,如果没有适当的测试就直接使用它可能会踩到坑。让我们看下面的视频:

体大小变得非常小,这不利于可访问性和用户体验。据我所知,移动设备上的最小字体大小不应该不于14px。在GIF中,不小于10px

要解决该问题,我们需要为标题提供最小字体大小,可以使用 calc()

 .title { font-size: calc(14px + 2vw); }

calc()CSS函数将具有一个最小值14px,并在些基础上添加2vw的值,有了这些,字体大小值就不会变得太小。

另一个需要考虑的重要问题是字体大小在大屏幕上的表现,例如 27” iMac。会发生什么呢?你猜对了,字体大小为95px左右,这是一个很大的值。为了防止这种情况,我们应该在某些断点上使用媒体查询并更改字体大小。

 @media (min-width: 1800px) { .title { font-size: 40px; } }

通过重置字体大小,我们可以确保大小不会太大。您可能还需要添加多个媒体查询,但这取决于你自己,也取决于项目的上下文。

事例地址:https://codepen.io/shadeed/pen/fa989837c6379770cce49f0be6daa3e3

全屏

有时,我们需要一个p来获取100%的视口高度,为此,我们可以使用viewport高度单位。

 .p { height: 100vh; display: flex; flex-direction: column; justify-content: center; align-items: center; }

通过添加 height: 100vh,我们可以确保p 高度将采取100%的视口。此外,我们添加了一些flexbox来处理水平和垂直居中的内容。

事例源码:https://codepen.io/shadeed/pen/dc4e82f3c873cc64ae5c5bc4a3f4ef9f?editors=1100

粘性布局(footer)

在大屏幕上,网站内容有时候很少,footer 没有粘在底部。这很正常,也不被认为是一种不好的做法。但是,还有改进的余地。考虑下面代表问题的示图:

为了解决这个问题,我们需要给内容(content)一个高度,它等于视口高度- (header + footer)。动态地做到这一点是很困难的,但是使用CSS的视口,这是很容易的。

第一种解决方案:calc和视口单位

如果headerfooter的高度是固定的,那么可以将calc()函数和视口单位结合起来,如下所示:

 header, footer { height: 70px; } main { height: calc(100vh - 70px - 70px); }

不能保证此解决方案始终有效,尤其是对于footer而言。在我的职业生涯中,我没有使用固定高度的页脚,因为在例如不同的屏幕尺寸下,此footer是不可行的。

2.第二种解决方案:Flexbox和视口单位(推荐

通过将100vh设置为body元素的高度,然后可以使用flexbox来使main元素占用剩余空间。

 body {     min-height: 100vh;     display: flex     flex-direction: column; { main {     /* This will make the main element take the remaining space dynamically */     flex-grow: 1; }

这样,问题就解决了,无论内容长度如何,我们都有一个粘性footer

事例源码:https://codepen.io/shadeed/pen/c735b26b8fa97ee685b38084448b3f85?editors=1100

响应式元素

假设我们有一个作品集来展示我们的响应式设计工作,并且我们有三种设备(移动设备、平板电脑和笔记本电脑)。每个设备包含一个图像。目标使用 CSS 来响应适配这些页面。

通过使用CSS网格和视口单位,我们可以使其完全动态的响应式。

视口单位也可以用于grid- *属性,也用于borderborder-radius和其他属性。

 .wrapper {   display: grid;   grid-template-columns: repeat(20, 5vw);    grid-auto-rows: 6vw; } .mobile {    position: relative;   z-index: 1;   grid-column: 2 / span 3;   grid-row: 3 / span 5; }   .tablet {   position: relative;   z-index: 1;   grid-column: 13 / span 7;    grid-row: 4 / span 4;   border-bottom: 1vw solid #a9B9dd;   border-right: solid 3vw #a9B9dd; }   .laptop {   position: relative;   grid-column: 3/span 13;   grid-row: 2 / span 8; } /* Viewport units are used for the bottom, left, right, height, and border-radius. Isn't that cool? */ .laptop:after {     content:"";     position:absolute;     bottom: -3vw;     left: -5.5vw;     right: -5.5vw;     height: 3vw;     background-color: #a9B9dd;     border-radius: 0 0 1vw 1vw; }

事例源码:https://codepen.io/shadeed/pen/2da0f2b70699769f8de3220ff4465bc6?editors=1100

从容器中挣脱出来

我注意到一个用例最适合编辑版面。一个子元素,即使父元素的宽度受到限制,它也会占据视口100%的宽度。考虑下面:

 .break-out { width: 100vw; position: relative; left: 50%; right: 50%; margin-left: -50vw; margin-right: -50vw; }

让我们把它分解一下,这样我们就能一点一点地理解所有这些属性是如何工作的。

1.添加 width: 100vw

最重要的一步,将图像的宽度设置为100%的视口。

2.添加 margin-left: -50vw

为了使图像居中,我们需要给它一个负的边距,其宽度为视口宽度的一半。

3.添加 left: 50%

最后,我们需要将图像向右推,其值为父宽度的50%

事例地址:https://codepen.io/sha

相关内容

-六神源码网