142 lines
3.7 KiB
Markdown
142 lines
3.7 KiB
Markdown
|
|
# Layout 布局
|
|||
|
|
|
|||
|
|
### 介绍
|
|||
|
|
|
|||
|
|
Layout 提供了 `van-row` 和 `van-col` 两个组件来进行行列布局。
|
|||
|
|
|
|||
|
|
### 引入
|
|||
|
|
|
|||
|
|
通过以下方式来全局注册组件,更多注册方式请参考[组件注册](#/zh-CN/advanced-usage#zu-jian-zhu-ce)。
|
|||
|
|
|
|||
|
|
```js
|
|||
|
|
import { createApp } from 'vue';
|
|||
|
|
import { Col, Row } from 'vant';
|
|||
|
|
|
|||
|
|
const app = createApp();
|
|||
|
|
app.use(Col);
|
|||
|
|
app.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>
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 垂直间距
|
|||
|
|
|
|||
|
|
如果需要设置垂直间距,可以使用数组形式设置 `[水平间距, 垂直间距]`。
|
|||
|
|
|
|||
|
|
```html
|
|||
|
|
<!-- 设置垂直间距 -->
|
|||
|
|
<van-row :gutter="[20, 20]">
|
|||
|
|
<van-col span="12">span: 12</van-col>
|
|||
|
|
<van-col span="12">span: 12</van-col>
|
|||
|
|
<van-col span="12">span: 12</van-col>
|
|||
|
|
<van-col span="12">span: 12</van-col>
|
|||
|
|
</van-row>
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 对齐方式
|
|||
|
|
|
|||
|
|
通过 `justify` 属性可以设置主轴上内容的对齐方式,等价于 flex 布局中的 `justify-content` 属性。
|
|||
|
|
|
|||
|
|
```html
|
|||
|
|
<!-- 居中 -->
|
|||
|
|
<van-row 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 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 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 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
|
|||
|
|
|
|||
|
|
| 参数 | 说明 | 类型 | 默认值 |
|
|||
|
|
| --- | --- | --- | --- |
|
|||
|
|
| gutter | 列元素之间的间距(单位为 px) | _number \| string \| Array_ | - |
|
|||
|
|
| tag | 自定义元素标签 | _string_ | `div` |
|
|||
|
|
| justify | 主轴对齐方式,可选值为 `end` `center` <br> `space-around` `space-between` | _string_ | `start` |
|
|||
|
|
| align | 交叉轴对齐方式,可选值为 `center` `bottom` | _string_ | `top` |
|
|||
|
|
| wrap | 是否自动换行 | _boolean_ | `true` |
|
|||
|
|
|
|||
|
|
### Col Props
|
|||
|
|
|
|||
|
|
| 参数 | 说明 | 类型 | 默认值 |
|
|||
|
|
| ------ | -------------- | ------------------ | ------ |
|
|||
|
|
| span | 列元素宽度 | _number \| string_ | - |
|
|||
|
|
| offset | 列元素偏移距离 | _number \| string_ | - |
|
|||
|
|
| tag | 自定义元素标签 | _string_ | `div` |
|
|||
|
|
|
|||
|
|
### Row Events
|
|||
|
|
|
|||
|
|
| 事件名 | 说明 | 回调参数 |
|
|||
|
|
| ------ | ---------- | ------------------- |
|
|||
|
|
| click | 点击时触发 | _event: MouseEvent_ |
|
|||
|
|
|
|||
|
|
### Col Events
|
|||
|
|
|
|||
|
|
| 事件名 | 说明 | 回调参数 |
|
|||
|
|
| ------ | ---------- | ------------------- |
|
|||
|
|
| click | 点击时触发 | _event: MouseEvent_ |
|
|||
|
|
|
|||
|
|
### 类型定义
|
|||
|
|
|
|||
|
|
组件导出以下类型定义:
|
|||
|
|
|
|||
|
|
```ts
|
|||
|
|
import type { ColProps, RowProps, RowAlign, RowJustify } from 'vant';
|
|||
|
|
```
|