写在前面
iOS 开发中经常使用绝对布局,描述试图自身相对父试图的位置关系,比如
view.frame = CGRectMake(10,20,30,40);
表示:view 在父试图的位置,横坐标和纵坐标分别为10和20,宽和高分别为30和40。
Flexbox 布局:描述子视图之间的关系。
Flexbox 主要属性对比
- flexDirection
- flexWrap
- justifyContent
- alignContent
- alignItems
- alignSelf
flexDirection
flexDirection:row|column|row-reverse|column-reverse
设置子视图布局主轴方向,默认为 column
比如:flexDirection 为 row,表示子视图布局的主轴为水平方向,副轴为竖直方向。
<View style={tmp_styles.containerStyle}>
<View style={tmp_styles.itemViewStyle}>
<Text>item1</Text>
</View>
<View style={tmp_styles.itemViewStyle}>
<Text>item2</Text>
</View>
<View style={tmp_styles.itemViewStyle}>
<Text>item3</Text>
</View>
<View style={tmp_styles.itemViewStyle}>
<Text>item4</Text>
</View>
</View>
const tmp_styles = StyleSheet.create({
containerStyle: {
flex: 1,
flexDirection: 'row',
margin: 5,
},
itemViewStyle: {
backgroundColor: 'darkcyan',
width: 60,
height: 35,
margin: 5
}
})
data:image/s3,"s3://crabby-images/2c5fd/2c5fd35b205937f8597cb2043fdd0c9f74e317df" alt=""
flexDirection 改为 column
data:image/s3,"s3://crabby-images/af915/af915d9de5117f797e74b546c39005bcdbb2402b" alt=""
flexWrap
子视图在主轴方向布局排列是否需要换行,默认 nowrap
flexWrap:wrap|nowrap|wrap-reverse
- nowrap:沿着主轴方向不换行显示
- wrap:沿着主轴换行显示
const tmp_styles = StyleSheet.create({
containerStyle: {
flex: 1,
flexDirection: 'row',
flexWrap: 'wrap',
margin: 5
},
itemViewStyle: {
backgroundColor: 'darkcyan',
justifyContent: 'center',
alignItems: 'center',
width: 100,
height: 30,
margin: 5
}
})
data:image/s3,"s3://crabby-images/548d8/548d8b5db29eec33ed2d22e69e12793eeae7aaee" alt=""
flexWrap 改为 nowrap
data:image/s3,"s3://crabby-images/7e859/7e859d52d7c4677c7f735a260a32bad34d405278" alt=""
flexWrap 改为 wrap-reverse
data:image/s3,"s3://crabby-images/2f07d/2f07da223f8e205fa66bc708f379ccc7c67f39e2" alt=""
justifyContent
justifyContent:子视图在主轴上的排列方式
justifyContent:flex-start|flex-end|center|space-between|space-around|space-evenly
使用 justifyContent 改为 center
const tmp_styles = StyleSheet.create({
containerStyle: {
flex: 1,
flexDirection: 'row',
justifyContent: 'center',
marginTop: 5
},
itemViewStyle: {
backgroundColor: 'darkcyan',
justifyContent: 'center',
alignItems: 'center',
width: 60,
height: 35,
margin: 5
}
})
data:image/s3,"s3://crabby-images/de46c/de46c43978d3d15785dd19b6dd8055ecaf4d7d9a" alt=""
alignContent
alignContent:子视图在副轴上的排列方式,flexWrap 为 wrap|wrap-reverse 才有效
alignContent:flex-start|flex-end|center|stretch|space-between|space-around
比如:
const tmp_styles = StyleSheet.create({
containerStyle: {
flex: 1,
flexDirection: 'row',
flexWrap: 'wrap',
alignContent: 'center',
margin: 5
},
itemViewStyle: {
backgroundColor: 'darkcyan',
justifyContent: 'center',
alignItems: 'center',
width: 100,
height: 30,
margin: 5
}
})
data:image/s3,"s3://crabby-images/0c89a/0c89aa65bb88cfee226e8b2f3db1e60d33a50b7d" alt=""
flexDirection 改为 column
data:image/s3,"s3://crabby-images/42ea4/42ea4ddbdfe1fb7c0ef587a9f9725ea447c5dd96" alt=""
alignItems
alignItems:子视图在副轴上的排列方式,flexWrap 为 nowrap 才生效
alignItems:flex-start|flex-end|center|stretch|baseline
const tmp_styles = StyleSheet.create({
containerStyle: {
flex: 1,
flexDirection: 'row',
flexWrap: 'nowrap',
alignItems: 'center',
marginTop: 5
},
itemViewStyle: {
backgroundColor: 'darkcyan',
justifyContent: 'center',
alignItems: 'center',
width: 60,
height: 35,
margin: 5
}
})
data:image/s3,"s3://crabby-images/5496c/5496c2052d189b6d18330d2891d1eb1f15517921" alt=""
flexDirection 改完 column
data:image/s3,"s3://crabby-images/d346a/d346abf811bda298a2c9c6e23aef7a151f36c959" alt=""
alignSelf
alignSelf:align-items 在伸缩容器上使用它,伸缩容器内部所有的元素都一致地受制于 align-items 的值。但是有些时候,我们希望伸缩容器内部某个元素在侧轴上的排列方式有所差异。此时就不能使用 align-items,因为 align-items 作用于整体。我们希望作用于部分。这就是 align-self 的发挥场地。
alignSelf:默认 auto,继承父容器的值
alignSelf:auto|flex-start|flex-end|center|stretch|baseline
<View style={alignSelf_styles.containerStyle}>
<View style={alignSelf_styles.itemViewStyle}>
<Text>item1</Text>
</View>
<View style={alignSelf_styles.itemViewSpecialStyle}>
<Text>item2</Text>
</View>
<View style={alignSelf_styles.itemViewStyle}>
<Text>item3</Text>
</View>
<View style={alignSelf_styles.itemViewStyle}>
<Text>item4</Text>
</View>
</View>
const alignSelf_styles = StyleSheet.create({
containerStyle: {
flex: 1,
flexDirection: 'column',
flexWrap: 'nowrap',
alignItems: 'center',
margin: 5
},
itemViewStyle: {
backgroundColor: 'darkcyan',
width: 60,
height: 30,
margin: 5
},
itemViewSpecialStyle: {
backgroundColor: 'darkcyan',
flexWrap: 'nowrap',
alignSelf: 'flex-start',
width: 60,
height: 30,
margin: 5
}
})
data:image/s3,"s3://crabby-images/93301/933010b5e7299d93a0f178e13d7b916edb65777b" alt=""
总结
标题 | 描述 | 枚举值 | 条件 |
---|---|---|---|
flexDirection | 设置主轴方向(水平or竖直) | row, column, row-reverse, column-reverse | 无 |
flexWrap | 子视图在主轴方向布局排列是否需要换行 | wrap, nowrap, wrap-reverse | 无 |
justifyContent | 子视图在主轴上的排列方式 | flex-start, flex-end, center, space-between, space-around, space-evenly | 无 |
alignContent | 子视图在副轴上的排列方式 | flex-start, flex-end, center, stretch, space-between, space-around | flexWrap 为 wrap, wrap-reverse 才有效 |
alignItems | 子视图在副轴上的排列方式 | flex-start, flex-end, center, stretch, baseline | flexWrap 为 nowrap 才生效 |
alignSelf | 在子视图中个性化父试图的 alignItems 定义 | auto, flex-start, flex-end, center, stretch, baseline | 无 |
data:image/s3,"s3://crabby-images/6d0e2/6d0e2239d6422ed5a30b4354751f446160deeff6" alt=""
data:image/s3,"s3://crabby-images/23cd6/23cd6a3f679ed66539df46337adb8da60a5ee634" alt=""
data:image/s3,"s3://crabby-images/60d48/60d489a8cba4115fc3a642d31a4ce3d96e77fea0" alt=""
data:image/s3,"s3://crabby-images/e0967/e096747f798ee984d9b2f89aa347842ee967d329" alt=""
data:image/s3,"s3://crabby-images/55760/557604c55a3a66ecdcb90945002870ed84820671" alt=""
网友评论