弹性和网格
用于控制元素在网格行中的大小和放置方式的实用程序。
使用 row-span-*
实用程序使元素跨越 n 行。
<div class="grid grid-rows-3 grid-flow-col gap-4">
<div class="row-span-3 ...">01</div>
<div class="col-span-2 ...">02</div>
<div class="row-span-2 col-span-2 ...">03</div>
</div>
使用 row-start-*
和 row-end-*
实用程序使元素在第 n 条网格线上开始或结束。它们还可以与 row-span-*
实用程序结合使用,以跨越特定数量的行。
请注意,CSS 网格线从 1 开始,而不是从 0 开始,因此 3 行网格中的全高元素将从第 1 行开始,到第 4 行结束。
<div class="grid grid-rows-3 grid-flow-col gap-4">
<div class="row-start-2 row-span-2 ...">01</div>
<div class="row-end-3 row-span-2 ...">02</div>
<div class="row-start-1 row-end-4 ...">03</div>
</div>
Tailwind 允许您使用变体修饰符有条件地在不同状态下应用实用程序类。例如,使用 hover:row-span-4
来仅 在 hover应用 row-span-4
.
<div class="row-span-3 hover:row-span-4">
<!-- ... -->
</div>
详细了解, 请参考 Hover, Focus, & Other States 文档.
您还可以使用变体修饰符来定位媒体查询,例如响应式断点、暗模式、首选减少运动等。例如, 使用 md:row-span-4
来应用 row-span-4
程序,适用于中等屏幕尺寸及以上。
<div class="row-span-3 md:row-span-4">
<!-- ... -->
</div>
默认情况下,Tailwind 包含网格行实用程序,用于处理最多具有 6 个显式行的网格。您可以通过在 tailwind.config.js
文件中编辑 theme.gridRow
、theme.extend.gridRow
、theme.gridRowStart
、theme.extend.gridRowStart
、theme.gridRowEnd
和 theme.extend.gridRowEnd
来自定义这些值。
要添加新的 row-*
实用程序,请自定义 Tailwind 主题配置的 gridRow
部分:
module.exports = {
theme: {
extend: {
gridRow: {
'span-16': 'span 16 / span 16',
}
}
}
}
我们在内部将其用于我们的 row-span-*
实用程序。请注意,由于这直接配置了 grid-row
简写属性,因此我们直接在值名称中包含单词 span
,它不会自动嵌入到类名中。这意味着您可以自由添加执行任何您想要的条目 - 它们不一定是 span
实用程序。
要添加新的 row-start-*
实用程序,请自定义 Tailwind 主题配置的 gridRowStart
部分:
module.exports = {
theme: {
extend: {
gridRowStart: {
'8': '8',
'9': '9',
'10': '10',
'11': '11',
'12': '12',
'13': '13',
}
}
}
}
要添加新的 row-end-*
实用程序,请自定义 Tailwind 主题配置的 gridRowEnd
部分:
module.exports = {
theme: {
extend: {
gridRowEnd: {
'8': '8',
'9': '9',
'10': '10',
'11': '11',
'12': '12',
'13': '13',
}
}
}
}
在 theme customization 文档中了解有关自定义默认主题的更多信息。
如果您需要使用一次性的 grid row值,而该值没有必要包含在主题中,请使用方括号动态生成属性,使用任意值。
<div class="row-[span_16_/_span_16]">
<!-- ... -->
</div>
进一步了解,请参考 任意值 文档.