Layout 布局
介绍
Layout 提供了van-row
和van-col
两个组件来进行行列布局
引入
import Vue from 'vue';
import { Col, Row } from 'vant';
Vue.use(Col);
Vue.use(Row);
代码演示
基础用法
Layout 组件提供了24列栅格
,通过在Col
上添加span
属性设置列所占的宽度百分比
此外,添加offset
属性可以设置列的偏移宽度,计算方式与 span 相同
<van-row>
<van-col span="8">span: 8</van-col>
<van-col span="8">span: 8</van-col>
<van-col span="8">span: 8</van-col>
</van-row>
<van-row>
<van-col span="4">span: 4</van-col>
<van-col span="10" offset="4">offset: 4, span: 10</van-col>
</van-row>
<van-row>
<van-col offset="12" span="12">offset: 12, span: 12</van-col>
</van-row>
设置列元素间距
通过gutter
属性可以设置列元素之间的间距,默认间距为 0
<van-row gutter="20">
<van-col span="8">span: 8</van-col>
<van-col span="8">span: 8</van-col>
<van-col span="8">span: 8</van-col>
</van-row>
Flex 布局
将 type
属性设置为 flex 可以启用 flex 布局,便于进行灵活的对齐
<!-- 左对齐 -->
<van-row type="flex">
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
</van-row>
<!-- 居中 -->
<van-row type="flex" justify="center">
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
</van-row>
<!-- 右对齐 -->
<van-row type="flex" justify="end">
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
</van-row>
<!-- 两端对齐 -->
<van-row type="flex" justify="space-between">
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
</van-row>
<!-- 每个元素的两侧间隔相等 -->
<van-row type="flex" justify="space-around">
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
<van-col span="6">span: 6</van-col>
</van-row>
API
Row Props
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
type | 布局方式,可选值为flex | string | - |
gutter | 列元素之间的间距(单位为 px) | number | string | - |
tag | 自定义元素标签 | string | div |
justify | Flex 主轴对齐方式,可选值为 end center space-around space-between | string | start |
align | Flex 交叉轴对齐方式,可选值为 center bottom | string | top |
Col Props
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
span | 列元素宽度 | number | string | - |
offset | 列元素偏移距离 | number | string | - |
tag | 自定义元素标签 | string | div |
Row Events
事件名 | 说明 | 回调参数 |
---|---|---|
click | 点击时触发 | event: Event |
Col Events
事件名 | 说明 | 回调参数 |
---|---|---|
click | 点击时触发 | event: Event |