作者: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-height
和max-height
。 min-height
是即便内容很短也要放弃模态看起来好,max-height
是应用特定值限度其高度,而不是增加固定的高度。
总结
在设计一种体验时,最好从宽度和高度的角度来思考。垂直地调整浏览器的大小可能有点奇怪,但它也有它的劣势。在本文中,咱们探讨了垂直测试的重要性,以及咱们如何进行垂直测试,最初,提出了一些示例和用例,心愿对智米们有用。
编辑中可能存在的bug没法实时晓得,预先为了解决这些bug,花了大量的工夫进行log 调试,这边顺便给大家举荐一个好用的BUG监控工具 Fundebug。
原文:https://hadeed.com/article/re...
交换
有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。
本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。