微信小程序頁面布局方式采用的是Flex布局。

flex布局
Flex布局的特點:
微信小程序實現了Flex布局,簡單介紹下Flex布局在微信小程序中的使用。
伸縮容器
設有display:flex或者display:block的元素就是一個flex container(伸縮容器),里面的子元素稱為flex item(伸縮項目),flex container中子元素都是使用Flex布局排版。
display:block 指定為塊內容器模式,總是使用新行開始顯示,微信小程序的視圖容器(view,scroll-view和swiper)默認都是dispaly:block。
display:flex:指定為行內容器模式,在一行內顯示子元素,可以使用flex-wrap屬性指定其是否換行,flex-wrap有三個值:nowrap(不換行),wrap(換行),wrap-reverse(換行第一行在下面)
使用display:block(默認值)的代碼:
<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>
顯示效果:

block
改換成display:flex的顯示效果:

flex
可以從效果圖看到block和flex的區別,子元素view是在換行顯示(block)還是行內顯示(flex)。
主軸和側軸
Flex布局的伸縮容器可以使用任何方向進行布局。
容器默認有兩個軸:主軸(main axis)和側軸(cross axis)。
主軸的開始位置為主軸起點(main start),主軸的結束位置為主軸終點(main end),而主軸的長度為主軸長度(main size)。
同理側軸的起點為側軸起點(cross start),結束位置為側軸終點(cross end),長度為側軸長度(cross size)。詳情見下圖:

Flex-direction
注意,主軸并不是一定是從左到右的,同理側軸也不一定是從上到下,主軸的方向使用flex-direction屬性控制,它有4個可選值:
如果水平方向為主軸,那個垂直方向就是側軸,反之亦然。
四種主軸方向設置的效果圖:

示例圖
圖中的實例展示了使用了不同的flex-direction值排列方向的區別。
實例代碼:
<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>
運行效果:

flex-direction
對齊方式
子元素有兩種對齊方式:
justify-conent 定義子元素在主軸上面的對齊方式
align-items 定義子元素在側軸上對齊的方式
justify-content有5個可選的對齊方式:

justify-content
align-items表示側軸上的對齊方式:
align-tiems設置的對齊方式,和側軸的方向有關,下圖以flex-direction為row,側軸方向是從上到下,描述align-items的5個值顯示效果:

aign-items
有了主軸和側軸的方向再加上設置他們的對齊方式,就可以實現大部分的頁面布局了。
源代碼地址:https://github.com/jjz/weixin-mina/blob/master/pages/flex/flex.wxml
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
|
新聞熱點
疑難解答