国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

微信小程序 Flex布局詳解

2019-11-20 08:48:07
字體:
來源:轉載
供稿:網友

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

  1. Flex布局,是W3c在2009年提出的一種新的方案,可以簡便,完整,響應式的實現各種頁面布局。
  2. Flex布局提供了元素在容器中的對齊,方向以及順序,甚至他們可以是動態的或者不確定的大小的。
  3. Flex布局的主要特征是能夠調整其子元素在不同的屏幕大小中能夠用最適合的方法填充合適的空間。


flex布局

Flex布局的特點:

  1. 任意方向的伸縮,向左,向右,向下,向上
  2. 在樣式層可以調換和重排順序
  3. 主軸和側軸方便配置
  4. 子元素的空間拉伸和填充
  5. 沿著容器對齊

微信小程序實現了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個可選值:

  1. row :從左到右的水平方向為主軸
  2. row-reverse:從右到左的水平方向為主軸
  3. column:從上到下的垂直方向為主軸
  4. column-reverse從下到上的垂直方向為主軸

如果水平方向為主軸,那個垂直方向就是側軸,反之亦然。

四種主軸方向設置的效果圖:

示例圖

圖中的實例展示了使用了不同的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個可選的對齊方式:

  1. flex-start 主軸起點對齊(默認值)
  2. flex-end 主軸結束點對齊
  3. center 在主軸中居中對齊
  4. space-between 兩端對齊,除了兩端的子元素分別靠向兩端的容器之外,其他子元素之間的間隔都相等
  5. space-around 每個子元素之間的距離相等,兩端的子元素距離容器的距離也和其它子元素之間的距離相同。
  6. justify-content的對齊方式和主軸的方向有關,下圖以flex-direction為row,主軸方式是從左到右,描述jstify-content5個值的顯示效果:

justify-content

align-items表示側軸上的對齊方式:

  1. stretch 填充整個容器(默認值)
  2. flex-start 側軸的起點對齊
  3. flex-end 側軸的終點對齊
  4. center 在側軸中居中對齊
  5. baseline 以子元素的第一行文字對齊

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


aign-items

有了主軸和側軸的方向再加上設置他們的對齊方式,就可以實現大部分的頁面布局了。

源代碼地址:https://github.com/jjz/weixin-mina/blob/master/pages/flex/flex.wxml

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 平湖市| 鹤山市| 西华县| 鹰潭市| 松溪县| 东乡| 北海市| 岳阳市| 礼泉县| 巨野县| 城口县| 梅州市| 武宣县| 香河县| 池州市| 阿合奇县| 永靖县| 北海市| 湖口县| 博湖县| 昌宁县| 遂平县| 太白县| 牙克石市| 高要市| 丹江口市| 突泉县| 新干县| 威远县| 盐边县| 南昌县| 南川市| 广昌县| 乐清市| 巴里| 中西区| 辉县市| 南郑县| 固阳县| 云安县| 云安县|