微信小程序頁面佈局方式採用的是Flex
佈局。Flex
佈局,是W3c在2009年提出的一種新的方案,能夠簡便,完整,響應式的實現各類頁面佈局。
Flex佈局提供了元素在容器中的對齊,方向以及順序,甚至他們能夠是動態的或者不肯定的大小的。
Flex佈局的主要特徵是可以調整其子元素在不一樣的屏幕大小中可以用最適合的方法填充合適的空間。git
Flex佈局的特色:github
微信小程序實現了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>
顯示效果:
改換成display:flex
的顯示效果:微信
能夠從效果圖看到block
和flex
的區別,子元素view
是在換行顯示(block
)仍是行內顯示(flex
)。佈局
Flex
佈局的伸縮容器能夠使用任何方向進行佈局。
容器默認有兩個軸:主軸(main axis)和側軸(cross axis)。
主軸的開始位置爲主軸起點
(main start),主軸的結束位置爲主軸終點
(main end),而主軸的長度爲主軸長度
(main size)。
同理側軸的起點爲側軸起點
(cross start),結束位置爲側軸終點
(cross end),長度爲側軸長度
(cross size)。詳情見下圖:flex
注意,主軸
並非必定是從左到右
的,同理側軸
也不必定是從上到下
,主軸的方向使用flex-direction
屬性控制,它有4個可選值:spa
row
:從左到右的水平方向爲主軸row-reverse
:從右到左的水平方向爲主軸column
:從上到下的垂直方向爲主軸column-reverse
從下到上的垂直方向爲主軸若是水平方向爲主軸,那個垂直方向就是側軸,反之亦然。
四種主軸方向設置的效果圖:scala
圖中的實例展現了使用了不一樣的flex-direction
值排列方向的區別。
實例代碼:3d
<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>
運行效果:
子元素有兩種對齊方式:
justify-conent
定義子元素在主軸上面的對齊方式align-items
定義子元素在側軸上對齊的方式
justify-content
有5個可選的對齊方式:
flex-start
主軸起點對齊(默認值)flex-end
主軸結束點對齊center
在主軸中居中對齊space-between
兩端對齊,除了兩端的子元素分別靠向兩端的容器以外,其餘子元素之間的間隔都相等space-around
每一個子元素之間的距離相等,兩端的子元素距離容器的距離也和其它子元素之間的距離相同。justify-content
的對齊方式和主軸的方向有關,下圖以flex-direction
爲row
,主軸方式是從左到右
,描述jstify-content
5個值的顯示效果:align-items
表示側軸上的對齊方式:
stretch
填充整個容器(默認值)flex-start
側軸的起點對齊flex-end
側軸的終點對齊center
在側軸中居中對齊baseline
以子元素的第一行文字對齊align-tiems
設置的對齊方式,和側軸的方向有關,下圖以flex-direction
爲row
,側軸方向是從上到下
,描述align-items
的5個值顯示效果:
有了主軸和側軸的方向再加上設置他們的對齊方式,就能夠實現大部分的頁面佈局了。
源代碼地址:https://github.com/jjz/weixin-mina/blob/master/pages/flex/flex.wxml