Vant4 Vant4 Layout 布局

2024-02-25 开发教程 Vant4 匿名 5

介绍

Layout 提供了 ​van-row​ 和 ​van-col​ 两个组件来进行行列布局。

引入

通过以下方式来全局注册组件,更多注册方式请参考组件注册。

import { createApp } from 'vue';
import { Col, Row } from 'vant';
const app = createApp();
app.use(Col);
app.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>

对齐方式

通过 ​justify​ 属性可以设置主轴上内容的对齐方式,等价于 flex 布局中的 ​justify-content​ 属性。

<!-- 居中 -->
<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 -
tag自定义元素标签string div
justify主轴对齐方式,可选值为 endcenter
space-aroundspace-between
string start
align交叉轴对齐方式,可选值为 centerbottomstring top
wrap v3.0.11是否自动换行boolean true

Col Props

参数说明类型默认值
span列元素宽度number | string -
offset列元素偏移距离number | string -
tag自定义元素标签string div

Row Events

事件名说明回调参数
click点击时触发event: MouseEvent

Col Events

事件名说明回调参数
click点击时触发event: MouseEvent

类型定义

组件导出以下类型定义:

import type { ColProps, RowProps, RowAlign, RowJustify } from 'vant';