前台css网格布局的最佳实践
越来越常见的问题-现在人们正在用css网格布局来生产-似乎是“最好的做法是什么?”这个问题的简短答案是用规范中定义的布局方法。您选择用的规范的特定部分,以及如何将网格与其余布局方法(如Flexbox)相结合,是针对您正在尝试构建的模式以及您和团队想要如何工作所起作使用的。
从更深的角度来看,我认为这种对“最佳实践”的要求可可以表明人们对用与以前截然不同的布局方法缺乏信心。也许是由于我们正在用Grid来解决它设计不适合的事情,或者者我们应该用Grid。可可以是担心支持旧的浏览器,或者者网格如何适应我们的开发工作流程。
在本文中,我将尝试详情少量可可以被形容为最佳实践的东西,有些事情可可以并不需要担心。
调查
为了帮助理解这篇文章,我想知道其余人如何用网格布局在生产中,他们面临什么挑战,他们真正喜欢什么?能否存在常见的问题、问题或者方法。为了找出答案,我做了一个快速调查,讯问人们如何用网格布局,特别是他们最喜欢的,以及他们发现的挑战性。
在下面的文章中,我将引使用并直接引使用其中少量响应。我还将链接到许多其余资源,在那里您能找到更多关于所形容的技术。结果发现,在调查回答中,有很多值得有趣的文章能解开。我会探讨未来帖子中出现的少量其余事情。
无障碍
假如用网格规范中的任何一部分,您需要注意用时,它是当用任何可可以导致内容重新排序的内容:
作者必需用命令和网格放置属性来实现内容的可视化、非逻辑、重排。用这些特性来执行逻辑重排的样式表是不一致的。
— 网格规范:重新排序和可访问性
这并不是网格独有的,然而,如此容易地在两个维度中重新排列内容的可以力使得它成为网格的一个更大的问题。但是,假如用任何允许内容重新排序的方法–无论是Grid、Flexbox还是绝对定位–您需要注意不要将视觉体验与文档中内容的结构联络起来。屏幕阅读器(以及仅用键盘在文档中导航的人员)将按照源中项的顺序进行操作。
在用时需要特别小心的地方flex-direction在Flexbox中反转顺序;order属性在Flexbox或者Grid中;用任何方法放置网格项,假如它将项目移出文档中的逻辑顺序;以及用grid-auto-flow.
有关这个问题的更多信息,请参阅下列资源:
网格布局和可访问性-MDN
Flexbox与键盘导航断开
我应该用哪种网格布局方法?
“网格中有这么多选择,坚持编写一致的方式(例如命名网格线、定义网格模板-区域、fallbacks、媒体查询)是一个挑战,这样它即可以维护整个团队。”
— 米歇尔巴克
当您首先查看网格时,可可以会因创立布局的不同方式而显得非常困难。然而最终,所有这些都归结于从一个网格线到另一个线的位置。您能根据您正在努力实现的布局进行选择,以及对于您的团队和您正在构建的站点所做的工作。
没有正确的或者错误的方法。下面,我将探讨少量常见的混乱主题。我已经在前面的文章中已经提到了许多其余潜在的困惑。网格和障碍块.”
我应该用隐式还是显式网格?
您定义的网格grid-template-columns和grid-template-rows被称为显式网格。显式网格允许在网格上命名线条,也能使您可以够以网格的结尾来定位网格的末端。您将选择一个显式的Grid来完成这些事情,通常情况下,当您有一个布局时,所有的布局都是设计好的,并且清楚地知道您的网格线应该去哪里,以及轨道的大小。
我经常用隐式网格来解决行跟踪。我想定义列,但是行只会自动大小,并且会扩展到包含内容。您能在某种程度上控制隐式网格。grid-auto-columns和grid-auto-rows然而,你的控制比你定义的东西要少。
您需要确定您能否知道您拥有多少内容,因而您能确定行数和列数-在这种情况下您能创立一个显式网格。假如您不知道您有多少内容,但是只要要行或者列来保存任何内容,您将用隐式网格。
然而,这两种方法是有可可以的。在下面的css中,我在显式网格中定义了三个列和三个行,因而四行内容将如下:
最高的轨道,至少在高度上,但扩展以使内容更高,
一条固定在1米高的跑道,
至少高度的轨道(但扩展)。
任何进一步内容都将进入隐式网格中创立的行,并且我用grid-auto-rows属性使这些轨道至少高出1,000米,扩展到auto.
.grid { display: grid; grid-template-columns: 1fr 3fr 1fr; grid-template-rows: minmax(200px auto) 400px minmax(300px, auto); grid-auto-rows: minmax(300px, auto); grid-gap: 20px; }Copy
具备柔性列数的柔性网格
通过用重复符号、autofill和minmax,您能创立尽可可以多的音轨作为适合容器的模式,从而消除了媒体查询的需求在某种程度上。这种技术能在本视频教程并且在我最近的文章中也展现了相似的想法2018中基于媒体查询的响应设计.”
选择此技术时,当您高兴地满足内容在较少空间时减少低于先前内容,并且很高兴允许在尺寸大小上有很多灵活性。您已指定要显示您的列以最小大小显示,并将自动填充.
调查中有几个评论让我怀疑人们能否选择了这种方法,当他们真正想要一个固定数量的列的网格时。假如您最终在某些断点上出现不可预测的列数,那么您最好设置列数-并根据需要重新定义它,而不是用auto-fill或者auto-fit.
我们开发了响应性布局
免费数据驱动应使用程序
我应该使用哪种轨道上浆方法?
我在文章中详细形容了跟踪尺寸。那个盒子有多大?网格布局中的了解量但是,我经常会问到如何用哪种方法来用。尤其是,我被问到百分比大小和fr单位。假如您只用fr单元作为子元素,因而它不同于用百分比,由于它分配可使用空间。假如你把一个更大的项目放在一个轨道上,那么fr直到将工作是让这条轨道占使用更多的空间,并分配什么是剩余的。
.grid { display: grid; grid-template-columns: 1fr 1fr 1fr; grid-gap: 20px;}Copy
第一列更广泛,由于网格已经分配了更多的空间。
使fr单位分发全网格容器中的空间,您需要给它最小大小的0用minmax().
.grid { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr) minmax(0,1fr); grid-gap: 20px;}Copy
强制设置0的最小值可可以会导致溢出。
所以你能选择用fr在其中的任一种场景中:您希望从自动(默认行为)和那些需要相等分布的方法来分配空间分配。我通常用fr单位,而后它为您制定大小,并允许用固定的宽度轨道或者间隙。我唯一用百分比的时候是当我将网格组件增加到用其余布局方法的现有布局中时。假如我希望我的网格组件与用百分比的基于浮动或者柔性的布局对齐,那么在我的网格布局中用它们意味着所有的东西都用相同的大小调整方法。
自动放置物品还是设置他们的位置?
您通常会发现您只要要在布局中放置一两个项,其他项则根据内容顺序进行设置。事实上,这是一个非常好的测试,您没有断开源和可视化显示。假如事情几乎都是基于自动放置的位置,那么他们可可以会处于良好的秩序状态。
一旦我决定了一切都到哪里去了,我就会倾向于给所有东西分配一个位置。这意味着假如有人向文档增加少量东西,网格自动地将它放置在某个意想不到的地方,那么我不会由于奇怪的事情发生而发生。假如所有东西都放置好了,网格将把该项目放入下一个可使用的空网格单元中。这可可以并不是你想要的地方,但是坐在你布局结束时坐下来可可以比进入中间的东西更好,并推其余东西。
哪种定位方法用?
当用网格布局时,最终所有事情都归结为将项目从一行中放置到另一个行。其余一切本质上都是这方面的帮助者。
假如您想要命名行,请选择您的团队,用网格模板区域,或者者您将用不同类型布局的组合。我发现我喜欢用网格模板区域来特别地用小组件。然而,没有对错之分。找出最适合你的东西。
网格与其余布局机制相结合
请记住,网格布局不是一个真正的布局方法来管理它们一律,它是设计为某种类型的布局-即二维布局。其余布局方法依然存在,您应该考虑每个模式和适合它最好。
我认为这对于我们来说非常困难,由于我们过去经常使用布局方法来进行黑客活动,让他们做少量他们不是真正设计出来的东西。现在是一个很好的时候迈出一步,看看他们设计的任务的布局方法,并记住要用它们来完成这些任务。
尤其是无论我多久写一篇关于网格和Flexbox的文章,我都会问到哪一个人应用。有很多模式,无论布局方法都有完美的意义,它真的取决于您。没有人会对你大声地喊你,由于你选择了网格,或者者是在Flexbox上的网格。
在我自己的工作中,我倾向于用Flexbox来实现组件,由于我希望物品的自然大小可以够强烈地控制它们的布局,基本上将其余项目推到附近。我也经常用Flexbox,由于我想要对齐,由于box比对属性仅使用于Flexbox和grid中。我可可以有一个带有一个子项的flex容器,以便使我可以够对该子项目进行调整。
可可以是Flexbox的标志不是我应该选择的布局方法,就是当我开始为flex项目增加百分比宽度和设置时。flex-grow
到0。添加对flex项目的百分比宽度的起因常常是由于我试图将它们按两个维度进行线性化(在两个维度上构建事物正好是网格所需要的)。不过,试一下两者,看看哪种看起来适合内容或者设计模式最好。你不太可可以通过这样做而产生任何疑问。
嵌套网格和flex项目
这也产生了很多,并且创立网格项目也没有问题,因而网格容器也是如此,因而在另一个网格中嵌套一个网格。您能在Flexbox中做同样的操作,创立一个flex项目和flex容器。您还能创立网格项目和flex容器或者一个网格容器flex项目-这些都不是问题!
目前我们不可以做的就是嵌套一个网格,并且嵌套网格用定义在父级的网格跟踪。这将是非常有使用的,也是最有使用的建议网格规范的第2级希望可以处理。嵌套网格现在变成了一个新网格,因而您需要小心调整大小以确保它与任何父音轨相一致。
您能在一个页面上拥有许多网格
调查中出现了几次评论,令我吃惊的是,似乎有一个想法认为网格应该局限于主布局,而一个页面上的许多网格可可以不是一个好东西。您能拥有尽可可以多的网格,您喜欢!用网格来做大事情和小事情,假如它把意义放在网格上,而后用网格。
支持旧浏览器和支持旧浏览器
“与@支持一起用的网格使我们可以够更好地控制我们期望看到的布局变化数量。它还与我们的渐进式加强方法非常有效,意味着我们能使用现代浏览器奖励那些不允许对那些不用最新技术的人提供内容的方法。
— 乔·兰伯特工作n.rareloop.com
在调查中,许多人提到了旧浏览器,但是,那些认为支持老浏览器很难的人之间有着相当平等的分歧,那些认为因为功可以查询和网格覆盖其余布局方法而感到轻松的人。我已经写了少量关于创立这些fallbacks的原理。用css网格:无网格支持浏览器.”
一般来说,现代浏览器比以前的浏览器更具备互操作性。我们通常会看到更少实际的“浏览器bug”,假如您正确用html和css,那么您通常会发现在浏览器中看到的内容与另一个浏览器中的情况相同。
当然,我们的确有一个浏览器尚未为某个规范或者规范的某些部分提供支持的情况。随着网格的发展,我们非常幸运的是,浏览器在一个非常完整和互操作性的方式中发送网格布局,在短时间内彼此之间。因而,我们对测试的考虑往往需要用网格测试浏览器,而无需网格。您也能选择用-ms
在IE10和IE11中前缀版本,而后要求测试作为第三类型的浏览器。
支持现代网格布局(而不是ie版本)的浏览器也支持特征查询。这意味着在用网格支持之前,您能测试网格支持。
测试不支持网格的浏览器
当不支持网格布局时用fallbacks来进行浏览器(或者用-ms对于IE10和11的前缀版本,您将想要测试这些浏览器如何呈现网格布局。要做到这一点,您需要一种方法来查看示例浏览器中的站点。
我不会通过检查能否支持少量荒谬的东西,或者者拼写错误的值来破坏您的功可以查询。grid
。假如样式表非常简单,那么这种方法只会有效,并且您完全能将所有内容都与您的网格布局完全结合在特征查询中。这是一个非常脆弱和耗时的工作方式,尤其是假如您广泛用网格。此外,一个旧浏览器不仅缺乏对网格布局的支持,还有其余css属性也不支持。假如你正在寻觅“最佳实践”,那么设置自己,这样你就可以在很好的位置测试你的工作是高的上面!
有几种简单的方法来设置一个正确的方法来测试您的fallbacks。最简单的方法-假如你有一个正当快速的互联网连接,并且不介意支付订阅费-就是用诸如BrowserStack这样的服务。这是一种服务,能在整个真实浏览器上查看网站(甚至是在计算机上开发的网站)。BrowserStack的确提供了开放源码项目免费账户.
要在本地进行测试,我的建议是用安装目标浏览器的虚拟机。微软提供免费服务。虚拟机下载将ie版本重新回到ie8,还有edge。您还能安装到虚拟机上,一个旧版本的浏览器,根本没有网格支持。例如,获取一个firefox 51或者以下的副本。安装了您的老firefox之后,请确保关闭自动升级,如这里所说明的否则它会悄悄地升级自己!
而后您能在IE11中测试您的站点,而后在一个vm上进行非支持firefox(比拼写错误值更少的脆弱处理方案)。设置起来可可以需要你一个小时左右,但是你会在一个非常好的地方测试你的自我评估。
unlearning旧习惯
“这是我第一次用网格布局,所以有很多概念要学习,属性了解。”从概念上讲,我发现最困难的事情是忘掉我多年来做过的所有事情,比方清除漂浮物,把所有东西打包在集装箱里。
— 希德工作hiddedevries.nl/en
许多回应这项调查的人提到,需要改掉旧习惯,以及如何更容易地学习布局对于完全新的css来说更容易。我倾向于同意。当人们对人进行教学时,初学者用网格时遇到的问题很少,而经验丰富的开发者则努力将网格返回到一维布局方法中。我已经看到了用css网格来尝试“网格系统”的尝试,它将返回使用于浮动或者基于flex的网格所需的行包装器。
不要害怕尝试新技术。假如您有可以力在几个浏览器中测试并保持注意潜在的可访问性问题,那么您真的不可以太过错误。假如你找到了一个创造某种模式的伟大方法,让其余人知道它。我们都是新的用网格生产的新产品,所以一定有很多东西能发现和分享。
“网格布局是自媒体查询以来最令人兴奋的css开发。对于现实世界开发者来说,这是一个非常好的想法,它是生产中用的绝对乐趣-对于设计师和开发者来说都是一样的。
— 试着尝试工作n.trysmudford.com
为了包装,这里有一个非常简短的列表当前最佳实践!假如你发现了那些在你自己情况下做或者不起作使用的事情,那么请把它们增加到评论中。
要非常清楚内容重新排序的可可以性。检查您没有断开来自文档顺序的可视化显示。
用本地或者远程虚拟机用实际目标浏览器进行测试。
不要不记得,旧的布局方法依然有效和有使用。尝试不同的方式来实现模式。不要由于不得不用Grid而挂断。
知道,作为一个经验丰富的前台开发人员,您可可以会对布局如何工作有一个整体的先入为主的看法。试着重新审视这些新方法,而不是强迫它们回到旧模式。
继续试着去做。我们都是新来的。测试你的工作并分享你所发现的东西。
关注小编理解更多精彩内容,还可私信“学习”,领取精品的前台免费学习课程视频,同时我将为您分享精品资料。
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 前台css网格布局的最佳实践