首先,了解下官方概念。
flexDirection
在组件的style中指定flexDirection可以决定布局的主轴。子元素是应该沿着水平轴(row)方向排列,还是沿着竖直轴(column)方向排列呢?默认值是竖直轴(column)方向。
justifyContent
在组件的style中指定justifyContent可以决定其子元素沿着主轴的排列方式。子元素对应的这些可选项有:flex-start、center、flex-end、space-around以及space-between。
alignItems
在组件的style中指定alignItems可以决定其子元素沿着次轴(与主轴垂直的轴,比如若主轴方向为row,则次轴方向为column)的排列方式。子元素对应的这些可选项有:flex-start、center、flex-end以及stretch。
创建个最简单的界面,代码如下图
data:image/s3,"s3://crabby-images/1c4de/1c4deb57e30ad46f2548ade83022a5a88a82684b" alt=""
-
flexDirection :'row'
时,改变justifyContent
的情况:
data:image/s3,"s3://crabby-images/4665c/4665ca576222bd16db0537c98e0c76340b476f10" alt=""
data:image/s3,"s3://crabby-images/b31e8/b31e8c1d0bcfef30103237db683458019ac7ea13" alt=""
data:image/s3,"s3://crabby-images/de6f7/de6f79300a7302de6c5d263ba58fb69580c93431" alt=""
data:image/s3,"s3://crabby-images/a8d11/a8d117856b372fc5f2a003d144dfece12608a05f" alt=""
data:image/s3,"s3://crabby-images/b0a29/b0a2950623d70337dbbf9994887d580ea774b8e5" alt=""
-
flexDirection :'column'
时,改变justifyContent
的情况:
data:image/s3,"s3://crabby-images/8d53c/8d53c607b293302af4d07a5bf6c5ebb19e921732" alt=""
data:image/s3,"s3://crabby-images/67a6b/67a6b62fe82fbec1daeed38cbae213e1259bb8bf" alt=""
data:image/s3,"s3://crabby-images/197c6/197c639625b55ea242c81f215434fc6156057b47" alt=""
data:image/s3,"s3://crabby-images/ba77a/ba77ae2a758f9ceb4a9baaf379da64bc81a1cc76" alt=""
data:image/s3,"s3://crabby-images/b3c14/b3c14eec9228a0614922d3604b737c4f10c3f869" alt=""
-
flexDirection :'row', justifyContent:'center'
时,改变alignItems
的情况:
data:image/s3,"s3://crabby-images/fb72e/fb72ea2bfd5e1022b44c3420080bb977a7ede1f7" alt=""
data:image/s3,"s3://crabby-images/64c17/64c1754f8ff6bbffcd3dcff784a826c41b5f2112" alt=""
data:image/s3,"s3://crabby-images/c175d/c175df6535af02fcb6a20a8292bbb9a6cb3ce31b" alt=""
data:image/s3,"s3://crabby-images/54906/54906d53ad614f31005426dffb8f72ddb62fd95a" alt=""
-
注意:要使stretch选项生效的话,子元素在次轴方向上不能有固定的尺寸。
网友评论