mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
125 lines
3.2 KiB
Markdown
125 lines
3.2 KiB
Markdown
# Layout 布局
|
||
|
||
### 介绍
|
||
|
||
Layout 提供了`van-row`和`van-col`两个组件来进行行列布局
|
||
|
||
### 引入
|
||
|
||
```js
|
||
import Vue from 'vue';
|
||
import { Col, Row } from 'vant';
|
||
|
||
Vue.use(Col);
|
||
Vue.use(Row);
|
||
```
|
||
|
||
## 代码演示
|
||
|
||
### 基础用法
|
||
|
||
Layout 组件提供了`24列栅格`,通过在`Col`上添加`span`属性设置列所占的宽度百分比
|
||
此外,添加`offset`属性可以设置列的偏移宽度,计算方式与 span 相同
|
||
|
||
```html
|
||
<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
|
||
|
||
```html
|
||
<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 布局,便于进行灵活的对齐
|
||
|
||
```html
|
||
<!-- 左对齐 -->
|
||
<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` <br> `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_ |
|