
弹性和网格
用于控制元素在网格行中的大小和放置方式的实用程序。
使用 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>
进一步了解,请参考 任意值 文档.