Layout 布局
介绍
Layout 提供了 Row 和 Col 两个组件来进行行列布局。
引入
js
import { createApp } from 'vue';
import { Col, Row } from '@szhn/dh-design-mobile';
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>对齐方式
通过 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 | - |
| justify | 主轴对齐方式 | string | start |
| align | 交叉轴对齐方式 | string | top |
| wrap | 是否自动换行 | boolean | true |
Col Props
| 参数 | 说明 | 类型 | 默认值 |
|---|---|---|---|
| span | 列元素宽度 | number | string | - |
| offset | 列元素偏移距离 | number | string | - |
Row Events
| 事件名 | 说明 | 回调参数 |
|---|---|---|
| click | 点击 Row 时触发 | event: MouseEvent |
Col Events
| 事件名 | 说明 | 回调参数 |
|---|---|---|
| click | 点击 Col 时触发 | event: MouseEvent |
类型定义
组件导出以下类型定义:
ts
import type { ColProps, RowProps, RowAlign, RowJustify } from '@szhn/dh-design-mobile';