Grid栅格—antd

布局的栅格化系统,是基于行(row)和列(col)来定义信息区块的外部框架,以保证页面的每个区域能够稳健地排布起来。下面简单介绍一下它的工作原理:

  • 通过 row 在水平方向建立一组 column(简写 col)
  • 内容应当放置于 col 内,并且只有 col 可以作为 row 的直接元素
  • 栅格系统中的列是指 1 到 24 的值来表示其跨越的范围。例如,三个等宽的列可以使用 (3*8=24) 来创建
  • 如果一个 row 中的 col 总和超过 24,那么多余的 col 会作为一个整体另起一行排列

栅格化系统支持 Flex 布局,允许子元素在父节点内的水平对齐方式 - 居左、居中、居右、等宽排列、分散排列。子元素与子元素之间,支持顶部对齐、垂直居中对齐、底部对齐的方式。同时,支持使用 order 来定义元素的排列顺序。

区块间隔

可以使用 Row 的 gutter 属性来设置区块间隔,推荐使用 (16+8n)px 作为栅格间隔。(n 是自然数)

响应式布局

如果要支持响应式,可以写成 { xs: 8, sm: 16, md: 24, lg: 32 }。
如果需要垂直间距,可以写成数组形式 [水平间距, 垂直间距] [16, { xs: 8, sm: 16, md: 24, lg: 32 }]

列偏移

使用 offset 可以将列向右侧偏。例如,offset={4} 将元素向右侧偏移了 4 个列(column)的宽度。
Row及Col的属性功能描述

Row

成员 说明 类型 默认值 版本
align flex 布局下的垂直对齐方式:top middle bottom string top
gutter 栅格间隔,可以写成像素值或支持响应式的对象写法来设置水平间隔 { xs: 8, sm: 16, md: 24}。或者使用数组形式同时设置 [水平间距, 垂直间距]3.24.0 后支持)。 number/object/array 0
justify flex 布局下的水平排列方式:start end center space-around space-between string start
type 布局模式,可选 flex,现代浏览器 下有效 string

Col

成员 说明 类型 默认值 版本
offset 栅格左侧的间隔格数,间隔内不可以有栅格 number 0
order 栅格顺序,flex 布局模式下有效 number 0
pull 栅格向左移动格数 number 0
push 栅格向右移动格数 number 0
span 栅格占位格数,为 0 时相当于 display: none number -
xs <576px 响应式栅格,可为栅格数或一个包含其他属性的对象 number object -
sm ≥576px 响应式栅格,可为栅格数或一个包含其他属性的对象 number object -
md ≥768px 响应式栅格,可为栅格数或一个包含其他属性的对象 number object -
lg ≥992px 响应式栅格,可为栅格数或一个包含其他属性的对象 number object -
xl ≥1200px 响应式栅格,可为栅格数或一个包含其他属性的对象 number object -
xxl ≥1600px 响应式栅格,可为栅格数或一个包含其他属性的对象 number object -