Layout 提供了van-row和van-col兩個(gè)組件來(lái)進(jìn)行行列布局
import Vue from 'vue';
import { Col, Row } from 'vant';
Vue.use(Col);
Vue.use(Row);
Layout 組件提供了24列柵格,通過(guò)在Col上添加span屬性設(shè)置列所占的寬度百分比此外,添加offset屬性可以設(shè)置列的偏移寬度,計(jì)算方式與 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>
通過(guò)gutter屬性可以設(shè)置列元素之間的間距,默認(rèn)間距為 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>
將 type 屬性設(shè)置為 flex 可以啟用 flex 布局,便于進(jìn)行靈活的對(duì)齊
<!-- 左對(duì)齊 -->
<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>
<!-- 右對(duì)齊 -->
<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>
<!-- 兩端對(duì)齊 -->
<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>
<!-- 每個(gè)元素的兩側(cè)間隔相等 -->
<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>
參數(shù) | 說(shuō)明 | 類(lèi)型 | 默認(rèn)值 |
---|---|---|---|
type | 布局方式,可選值為flex | string | - |
gutter | 列元素之間的間距(單位為px) | number | string | - |
tag | 自定義元素標(biāo)簽 | string | div |
justify | Flex 主軸對(duì)齊方式,可選值為 end center space-around space-between | string | start |
align | Flex 交叉軸對(duì)齊方式,可選值為 center bottom | string | top |
參數(shù) | 說(shuō)明 | 類(lèi)型 | 默認(rèn)值 |
---|---|---|---|
span | 列元素寬度 | number | string | - |
offset | 列元素偏移距離 | number | string | - |
tag | 自定義元素標(biāo)簽 | string | div |
事件名 | 說(shuō)明 | 回調(diào)參數(shù) |
---|---|---|
click | 點(diǎn)擊時(shí)觸發(fā) | event: Event |
事件名 | 說(shuō)明 | 回調(diào)參數(shù) |
---|---|---|
click | 點(diǎn)擊時(shí)觸發(fā) | event: Event |
代碼:
<body ontouchstart="">
<div>
<div class="demo-nav" style="">
<div class="demo-nav__title">Col</div>
<svg viewBox="0 0 1000 1000" class="demo-nav__back">
<path fill="#969799" fill-rule="evenodd" d="M296.114 508.035c-3.22-13.597.473-28.499 11.079-39.105l333.912-333.912c16.271-16.272 42.653-16.272 58.925 0s16.272 42.654 0 58.926L395.504 498.47l304.574 304.574c16.272 16.272 16.272 42.654 0 58.926s-42.654 16.272-58.926 0L307.241 528.058a41.472 41.472 0 0 1-11.127-20.023z"></path>
</svg>
</div>
<section class="van-doc-demo-section demo-col">
<div class="van-doc-demo-block">
<h2 class="van-doc-demo-block__title">基礎(chǔ)用法</h2>
<div class="van-row"><div class="van-col van-col--8">span: 8</div>
<div class="van-col van-col--8">span: 8</div>
<div class="van-col van-col--8">span: 8</div>
</div>
<div class="van-row">
<div class="van-col van-col--4">span: 4</div>
<div class="van-col van-col--10 van-col--offset-4"> offset: 4, span: 10</div>
</div>
<div class="van-row">
<div class="van-col van-col--12 van-col--offset-12">offset: 12, span: 12</div>
</div>
<div class="van-doc-demo-block">
<h2 class="van-doc-demo-block__title">在列元素之間增加間距</h2>
<div class="van-row">
<div class="van-col van-col--8" style="padding-right: 13.3333px;">span: 8</div>
<div class="van-col van-col--8" style="padding-left: 6.66667px; padding-right: 6.66667px;">span: 8</div>
<div class="van-col van-col--8" style="padding-left: 13.3333px; padding-right: 1.77636e-15px;">span: 8</div>
</div>
</div>
<div class="van-doc-demo-block">
<h2 class="van-doc-demo-block__title">Flex 布局</h2>
<div class="van-row van-row--flex">
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
</div>
<div class="van-row van-row--flex van-row--justify-center">
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
</div>
<div class="van-row van-row--flex van-row--justify-end">
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
</div>
<div class="van-row van-row--flex van-row--justify-space-between">
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
</div>
<div class="van-row van-row--flex van-row--justify-space-around">
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
<div class="van-col van-col--6">span: 6</div>
</div>
</div>
</section>
</div>
<script src="https://b.yzcdn.cn/vant/async_chunks.a839cbb5.js" rel="external nofollow" ></script><script src="https://b.yzcdn.cn/vant/site-mobile.ea70a230.js" rel="external nofollow" ></script></body>
運(yùn)行效果:
更多建議: