作者:Ahmad Shadeed
译者:前端小智
起源:ishadeed

有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。

大家看到这个题目可能会认为小智是不是又写错别字了 ,响应式高度设计?你认真的吗? 因为“响应式Web设计”通常是在多个宽度和设施尺寸上查看浏览器。 咱们个别通过减小宽度调整程度方向的响应能力,然而我很少看到通过减小浏览器高度来进行垂直响应的思考。 此时,智米么心田可能有一丝的稳定,并带有许些疑难:咱们须要升高浏览器的高度吗? 是的,咱们始终探讨一下。

当咱们在设计网站的时候,不依赖理论数据进行假如是不好的,程度和垂直测试的责任也是十分重要。

为什么要测试高度?

对于一个设计师来说,一个不合理的假如是毁掉一个网站设计的重要因素之一。例如,假如用户必定是通过应用屏幕的全宽和全高浏览网站是不正确的。相同,咱们须要思考最坏的状况。

智米么,看明确了吗。现实情况是,并非所有用户都依照咱们所冀望一样应用浏览器。 我发现升高浏览器高度时网站看起来很蹩脚。

浏览器 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。

<div class="hero">  <div class="hero__wrapper">    <div class="hero__content"><!-- content --></div>    <img class="hero__thumb" src="figure.png" alt="" />  </div></div>

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是有危险的,因为即便咱们限度了插图的大小,也可能无奈对文本内容执行雷同的操作。如果文本内容变长,同样的问题会再次发生,参见下图:

为了解决这个问题,咱们能够应用min-height而不是height。 这样,如果内容变长,高度将扩充并且不会重叠。

@media (min-height: 700px) {  .hero {    min-height: 100vh;  }}

固定头部

在滚动时固定题目并不是一件好事,然而,咱们要确保只有在垂直空间足够好的状况下才固定题目,这样体验才会好。

这是一个对于风光类的网站,这里咱们能够看到,当高度过小的时候,这个固定高度整体就会占用很大的空间。这个对用户真的重要吗?大多数状况是不重要的,因为个别用户不会缩小成这样去看一个网站。以后,如果咱们要优化也是能够就是,思路就是通过垂直媒体查问,判断高度小于某个高度的时候就将固定定位改成动态定位。

@media (min-height: 700px) {  .site-header {    /* position: fixed or position: sticky */  }}

暗藏不太重要的元素

我在Twitter.com的导航栏上留神到了这个模式。其思维是将垂直媒体查问和Priority+模式联合起来。

调整视口高度的大小时,次重要的元素(书签和列表)将被删除并附加到“更多”菜单中,这是垂直媒体查问的一个很好的用例。

.nav__item--secondary {  display: none;}@media (min-height: 700px) {  .nav__item--secondary {    display: block;  }}

缩小间距-导航

如果咱们网站有侧边栏或侧边栏,当视口高度很小时,咱们能够缩小一些导航项之间的垂直间距,这也会加强整体设计。

.nav__item {  padding-top: 4px;  padding-bottom: 4px;}@media (min-height: 700px) {  .nav__item {    padding-top: 10px;    padding-bottom: 10px;  }}

模态框

咱们晓得,模态框至多应该程度居中。然而,有时咱们还须要垂直居中,咱们个别会应用上面的计划:

.modal__body {  position: absolute;  left: 50%;  top: 50%;  transform: translate(-50%, -50%);  width: 500px;}

然而,当内容变长时就会有问题,模态框会垂直填满屏幕,用户将无奈滚动它。

引发这种状况下,有几点起因:

  • 模态框没有高度
  • 模态垂直居中(这会问题更快的呈现)

上面是修复后的 css:

.modal__body {  position: absolute;  left: 50%;  top: 3rem;  transform: translateX(-50%);  width: 500px;  min-height: 200px;  max-height: 500px;  overflow-y: auto;}@media (min-height: 700px) {  .modal__body {    top: 50%;    transform: translate(-50%, -50%);  }}

留神,我应用了min-heightmax-heightmin-height是即便内容很短也要放弃模态看起来好,max-height是应用特定值限度其高度,而不是增加固定的高度。

总结

在设计一种体验时,最好从宽度和高度的角度来思考。垂直地调整浏览器的大小可能有点奇怪,但它也有它的劣势。在本文中,咱们探讨了垂直测试的重要性,以及咱们如何进行垂直测试,最初,提出了一些示例和用例,心愿对智米们有用。


编辑中可能存在的bug没法实时晓得,预先为了解决这些bug,花了大量的工夫进行log 调试,这边顺便给大家举荐一个好用的BUG监控工具 Fundebug。

原文:https://hadeed.com/article/re...

交换

有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。