响应式网页中的高度设计,你认真的吗?,2024前端春招

浏览器 DevTools


调整浏览器的大小(垂直方向)并不是改变视口高度的唯一方法。当我们打开浏览器DevTools,它也会占用浏览器的高度。

上图中的箭头区域代表当前视口的高度,对于较小的笔记本电脑屏幕,我们只会看到一小部分网页。

真正的问题是:当视口高度较小时,我们可以增强用户体验吗? 是的,有可能,我们来一起看看。

CSS 中的垂直思考


作为设计师和开发人员,我们中的一些人只关注设计的宽度变化,而忽略了视口高度变化。例如,在开发中, UI 提供了特定组件在不同视口宽度上的变化。 但是,不同的视口高度又如何呢?

在上图中,我们有一个基于视区高度进行调整的导航菜单。。如果视口大小很小(比如,iPhone 5),导航项将显示为一个两列网格。这种思维方式通常会被舍弃,或者直到有人说要做才会这么去优化。

CSS 中可以通过使用两种不同方式来实现上面的需求:

  • Vertical media queries

  • Viewport units

Vertical Media Queries


智米么肯定知识在CSS中使用宽度媒体查询。

@media (min-width: 700px) {

.element {

/* do something… */

}

}

较少使用的是垂直媒体查询,它检查视口高度。

@media (min-height: 500px) {

.element {

/* do something… */

}

}

/* or */

@media (orientation: landscape) {

.element {

/* do something… */

}

}

视口单位


使用视口单位可以帮助为用户提供更好的体验。 例如,根据视口高度控制元素之间的垂直间距。

.hero__title {

margin-bottom: calc(10px + 5vh);

}

如上所示,大比较大的屏幕(例如iMac 27英寸),下边距就会变的很大。我们有两种方式来解决边距过大的问题。

  • Media queries

  • CSS comparison 函数

第一种方式(媒体查询)受到更多支持。 如果屏幕很大,我们需要为下边距设置最大值。

@media (min-width: 2200px) {

.hero__title {

margin-bottom: 40px;

}

}

另一种方法是使用CSS clamp()比较函数,clamp() 函数的作用是返回一个区间范围的值。

.hero__title {

margin-bottom: clamp(10px, 5vh, 40px);

}

用例一:重叠内容


在此示例中,有一个section 区域,其中有标题和插图的部分, section 高度等于视口高度的100%。

一切看起来都很好,直到视口高度变小。section 的高度将不足以容纳插图和文本内容。因此,它将与页面上的其他部分重叠。

注意插图与下面的部分如何重叠。 发生这种情况是因为有足够的垂直空间。 看一下HTML和CSS。

css

.hero {

height: 100vh;

}

.hero__thumb {

flex: 0 0 550px;

width: 550px;

}

下面是解决此类问题几种解决方案:

  • 为插图设置固定大小(宽度和高度),而不是仅设置宽度,缺乏高度将会继续存在这个问题。

  • 仅当视口高度大于700px时才为height: 100vh(媒体查询值可能会根据上下文而有所不同)。

我们可以将两者结合起来,获得更强大的解决方案。

.hero__thumb {

width: 400px;

height: 300px;

object-fit: contain; /* To avoid compressing the image */

}

@media (min-height: 700px) {

.hero {

height: 100vh;

}

好的,现在我们同意使用垂直媒体查询更好。然而,使用100vh是有风险的,因为即使我们限制了插图的大小,也可能无法对文本内容执行相同的操作。如果文本内容变长,同样的问题会再次发生,参见下图:

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:前端)
img

何学起的朋友,同时减轻大家的负担。**

[外链图片转存中…(img-uhm8bqyG-1710921702324)]
[外链图片转存中…(img-FfTcnTU7-1710921702325)]
[外链图片转存中…(img-NhAQzTbI-1710921702325)]
[外链图片转存中…(img-1bJGuO5j-1710921702325)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注:前端)
[外链图片转存中…(img-RfYkGX1T-1710921702325)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值