那么,使用 Flex 到底有什么優(yōu)勢(shì)?Flex 中有多少排版模式?如何正確使用 Flex 排版?
今天,知曉程序(微信號(hào) zxcx0101)就來帶大家看看 Flex 的正確使用方法。希望本文可以幫助大家,利用好 Flex 構(gòu)建具有良好體驗(yàn)的小程序。
微信小程序頁面布局方式采用 Flex 布局格式,它是 W3c 在 2009 年提出的一種新的網(wǎng)頁排版方案,可以簡便、完整地實(shí)現(xiàn)各種響應(yīng)式頁面布局。
Flex 布局的主要特點(diǎn)是:能夠讓同級(jí)元素在不同的屏幕大小中,用最適合的方法填充空間。同時(shí),F(xiàn)lex 提供了元素在容器中的對(duì)齊方式、對(duì)齊方向以及元素順序,甚至被編排的元素可以是動(dòng)態(tài)的或是不確定的大小的。
Flex 布局有如下特點(diǎn):
- 任意方向的伸縮
- 在樣式層可以調(diào)換和重排順序
- 主軸和側(cè)軸方便配置
- 子元素的空間拉伸和填充
- 沿容器對(duì)齊
本文將會(huì)簡單介紹 Flex 布局在微信小程序中的使用。
伸縮容器
在小程序中,設(shè)有 display: flex
或者 display: block
的元素就是一個(gè) flex container(伸縮容器),里面的子元素稱為 flex item(伸縮項(xiàng)目)。在 flex container 中,子元素都可以使用 Flex 進(jìn)行布局。
display: block
指定為塊內(nèi)容器模式,總是使用新行開始顯示,微信小程序的視圖容器(view
、scroll-view
和swiper
)會(huì)默認(rèn)設(shè)置display: block
;display:flex
:指定為行內(nèi)容器模式。在一行內(nèi)顯示的子元素,可以使用flex-wrap
屬性指定其是否換行、如何換行。flex-wrap
有三個(gè)值:nowrap
(不換行)、wrap
(向下?lián)Q行),以及wrap-reverse
(向上換行)。
假設(shè)我們有以下的代碼:
<view class="flex-row" style="display: block;">
<view class="flex-view-item">1</view>
<view class="flex-view-item">2</view>
<view class="flex-view-item">3</view>
</view>
使用 display: block
(默認(rèn)值)時(shí),顯示效果如下:
改換成 display: flex
后,顯示效果如下:
我們可以從效果圖中清楚地看出 block
和 flex
的區(qū)別,即子元素 view
換行顯示(block
)和行內(nèi)顯示(flex
)的差異。
主軸和側(cè)軸
Flex 布局的伸縮容器可以使用任何方向進(jìn)行布局。
默認(rèn)情況下,容器有主軸(main axis)和側(cè)軸(cross axis)兩種軸。
主軸的開始位置為主軸起點(diǎn)(main start),主軸的結(jié)束位置為主軸終點(diǎn)(main end),而主軸的長度為主軸長度(main size)。
同理側(cè)軸的起點(diǎn)為側(cè)軸起點(diǎn)(cross start),結(jié)束位置為側(cè)軸終點(diǎn)(cross end),長度為側(cè)軸長度(cross size)。
注意,主軸并不是一定是從左到右的,同理側(cè)軸也不一定是從上到下。主軸的方向可以使用 flex-direction
屬性控制,它有 4 個(gè)可選值:
row
:從左到右的水平方向row-reverse
:從右到左的水平方向column:
從上到下的垂直方向column-reverse
:從下到上的垂直方向
如果水平方向?yàn)橹鬏S,那個(gè)垂直方向就是側(cè)軸,反之亦然。
四種主軸方向設(shè)置的效果圖:
圖中的實(shí)例展示了使用了不同的flex-direction
值排列方向的區(qū)別。
實(shí)例代碼:
<view>
<view class="flex-row" style="display: flex; flex-direction: row;">
<view class="flex-view-item">1</view>
<view class="flex-view-item">2</view>
<view class="flex-view-item">3</view>
</view>
<view class="flex-column" style="display: flex; flex-direction: column;" >
<view class="flex-view-item">c1</view>
<view class="flex-view-item">c2</view>
<view class="flex-view-item">c3</view>
</view>
</view>
運(yùn)行效果:
對(duì)齊方式
子元素有兩種對(duì)齊方式:
justify-conent
定義子元素在主軸上面的對(duì)齊方式;align-items
定義子元素在側(cè)軸上對(duì)齊的方式。
justify-content
有 5 個(gè)可選的對(duì)齊方式:
flex-start
:主軸起點(diǎn)對(duì)齊(默認(rèn)值);flex-end
:主軸結(jié)束點(diǎn)對(duì)齊;center
:在主軸中居中對(duì)齊;space-between
:兩端對(duì)齊,除了兩端的子元素分別靠向兩端的容器之外,其他子元素之間的間隔都相等;space-around
:每個(gè)子元素之間的距離相等,兩端的子元素距離容器的距離也和其它子元素之間的距離相同。
justify-content
的對(duì)齊方式和主軸的方向有關(guān)。下圖以 flex-direction
為 row
,主軸方式是從左到右,描述 justify-content
5 個(gè)值的顯示效果:
align-items
表示側(cè)軸上的對(duì)齊方式:
stretch
:填充整個(gè)容器(默認(rèn)值);flex-start
:側(cè)軸的起點(diǎn)對(duì)齊;flex-end
:側(cè)軸的終點(diǎn)對(duì)齊;center
:在側(cè)軸中居中對(duì)齊;baseline
:以子元素的第一行文字對(duì)齊。
align-tiems
設(shè)置的對(duì)齊方式,和側(cè)軸的方向有關(guān)。下圖以 flex-direction
為 row
,側(cè)軸方向是從上到下,描述 align-items
的 5 個(gè)值顯示效果:
有了主軸和側(cè)軸的方向再加上設(shè)置他們的對(duì)齊方式,就可以實(shí)現(xiàn)大部分的頁面布局了。
希望大家可以通過本文,熟悉 Flex 布局,開發(fā)出體驗(yàn)更好的小程序。
留言反饋