Dave Rupert巧妙地运用现代CSS解决了经典难题:当组件的CSS无法处理我们提供的内容时会发生什么?
具体情况是,当布局网格期望偶数个项目,但实际提供的是奇数个项目时。最后剩下的“悬空”元素会破坏布局。这需要一些防御性CSS,Dave做到了。
他使用:has()编写了一个简洁的选择器,用于查找包含奇数个项目的网格中的最后一个项目:
<code>.items:has(.item:last-of-type:nth-of-type(odd)) .item:first-of-type { }</code>
分解如下:
- 我们有一个名为.items的父容器。
- 如果该容器:has()一个.item子元素,它是其类型的最后一个,
- ……并且该.item恰好是奇数实例,
- ……那么选择该类型的第一个.item元素并设置其样式!
在这种情况下,最后一个.item可以设置为全宽,以防止布局出现空隙。
如果……那么……CSS具有条件逻辑能力!目前我们只讨论Safari TP和Edge/Chrome Canary的支持,但这已经非常棒了。
碰巧的是,Temani Afif最近分享了他使用隐式网格进行实验时学到的技巧。通过利用CSS Grid的自动放置算法,我们甚至不必为网格显式声明固定数量的列和行——如果需要,CSS会为我们创建它们!
不,Temani的技巧并不是Dave的“悬空”难题的替代方案。但是,将Temani对可重复网格布局模式的方法与Dave对:has()的防御性CSS用法相结合,我们得到了一个功能强大且外观复杂的网格,它轻量级且能够处理任意数量的项目,同时保持平衡的可重复模式。
以上是隐式网格,可重复的布局模式和悬挂的详细内容。更多信息请关注PHP中文网其他相关文章!

文章讨论了CSS保证金属性,特别是“保证金:40px 100px 120px 80px”,其应用程序以及对网页布局的影响。

本文讨论了CSS边境属性,重点是自定义,最佳实践和响应能力。主要论点:边境 - 拉迪乌斯(Border-Radius)对响应式设计最有效。

本文讨论了CSS中评论的使用,详细介绍了单线和多行评论语法。它认为注释可以增强代码可读性,可维护性和协作,但如果无法正确管理,可能会影响网站性能。

文章讨论了将CSS添加到HTML的三种方法:内联,内部和外部。分析了每种方法对网站性能和适合初学者的适用性的影响。(159个字符)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

WebStorm Mac版
好用的JavaScript开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Dreamweaver Mac版
视觉化网页开发工具

Atom编辑器mac版下载
最流行的的开源编辑器