IOS React Native FlexBox详解及实例

2025-05-29 0 40

ios react native flexbox详解及资料整理,

# 前言

学习本系列内容需要具备一定 html 开发基础,没有基础的朋友可以先转至 html 学习

本人接触 react native 时间并不是特别长,所以对其中的内容和性质了解可能会有所偏差,在学习中如果有错会及时修改内容,也欢迎万能的朋友们批评指出,谢谢

文章第一版出自简书,如果出现图片或页面显示问题,烦请转至简书查看 也希望喜欢的朋友可以点赞,谢谢

什么是 flexbox 布局

在 html 中,界面的搭建都是采用 css 的布局方式,css 是基于盒子模型,依赖于 display、position、float属性,这对于一些比如 垂直居中 的特殊布局来说非常不方便

flex 是一种全新的针对 web 和移动开发的布局方式,它可以简便、完整、响应式地实现各种页面布局,并且目前的所有浏览器已经支持这种布局方式,所以不用考虑兼容性方面的问题

flexbox 从字面上可以理解成:能够很容易变化以适应外界条件变化的通用矩形容器,也就是我们常听到的 弹性布局,它的宗旨就是 通过弹性的方式来第七和分布容器中内容的空间,使其能使用不同屏幕,为盒装模型提供最大的灵活性(这类似于 ios 开发中的atuolayout布局方式)

flexbox 布局主要思想是:让容器有能力让其子项目改变宽度、高度甚至是顺序,从而达到最佳填充可用空间的方式

react native 中的 flexbox 是这个规范的一个子集

综上所述,flexbox 就是用来解决 父盒子 和 子盒子 之间的约束关系,如下图

IOS React Native FlexBox详解及实例

flexbox 在开发中能够解决下面等问题

  1. 浮动布局
  2. 水平和垂直居中
  3. 自动分配宽度
  4. 各种机型屏幕适配
  5. 动态分配子集的尺寸、位置等等

如下图所示,在 css 中,常规的布局是基于块和内联流方向,而 flex布局是基于 flexflow流【容器默认存在两根轴:水平的主轴(main axis)垂直的交叉轴(cross axis),主轴的开始位置(与边框的交叉点)叫做 main start,结束的位置叫 main end;交叉轴的开始位置叫做 cross start,结束位置叫做 cross end。项目默认沿着主轴排列,单个项目占据的主轴空间叫做 main size,占据的交叉轴空间叫做 cross size】

IOS React Native FlexBox详解及实例

根据伸缩项目排列方式的不同,主轴和侧轴方向也会变化,如下图所示

IOS React Native FlexBox详解及实例

IOS React Native FlexBox详解及实例

获取主屏幕尺寸

为了后面更好的展示案例,我们先来看看如何获取主屏幕的尺寸和分辨率

首先,我们需要先导入 dimensions
// 导入类库 var dimensions = require('dimensions');

接下来就可以在需要的地方使用 dimensions 变量获取屏幕的高度、宽度、分辨率等等数据

?

1

2

3

4

5

6

7

8

9

10
export default class testrn extends component {

render() {

return (

<view style={styles.container}>

<text>当前屏幕的宽度:{dimensions.get('window').width}</text>

<text>当前屏幕的高度:{dimensions.get('window').height}</text>

</view>

);

}

}

设置样式 // 样式 const styles = stylesheet.create({ container: { backgroundcolor:'blue' }, });

效果:IOS React Native FlexBox详解及实例

既然能拿到屏幕的尺寸,那么就能够直接将主 view 的大小设置成屏幕的尺寸,使 view 填充整个屏幕

?

1

2

3

4

5

6

7

8
// 样式

const styles = stylesheet.create({

container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width

},

});

效果:
IOS React Native FlexBox详解及实例

flexbox 常用容器属性

为了方便理解,我们先添加几个视图

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39
// 导入类库

var dimensions = require('dimensions');

// 入口

export default class testrn extends component {

render() {

return (

<view style={styles.container}>

<view style={styles.subviewstyle1}></view>

<view style={styles.subviewstyle2}></view>

<view style={styles.subviewstyle3}></view>

</view>

);

}

}

// 样式

const styles = stylesheet.create({

container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width

},

subviewstyle1: {

backgroundcolor:'red',

height:60,

width:60,

},

subviewstyle2: {

backgroundcolor:'yellow',

height:60,

width:60,

},

subviewstyle3: {

backgroundcolor:'green',

height:60,

width:60,

},

});

效果:
IOS React Native FlexBox详解及实例

flexdirection(该属性决定了项目排列的方向,也就是主轴的方向)row:主轴为水平方向,起点在左端

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置主轴方向

flexdirection:'row'

},

效果:
IOS React Native FlexBox详解及实例

row-reverse:主轴为水平方向,起点在右端

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置主轴方向

flexdirection:'row-reverse'

},

效果:
IOS React Native FlexBox详解及实例

column(默认):主轴为垂直方向,起点在上

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置主轴方向

flexdirection:'column'

},

效果:
IOS React Native FlexBox详解及实例

column-reverse:主轴为垂直方向,起点在下

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置主轴方向

flexdirection:'column-reverse'

},

效果:
IOS React Native FlexBox详解及实例

justifycontent(定义伸缩项目在主轴线的对齐方式)flex-start(默认):伸缩项目向一行的起始位置靠齐

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置子项目在主轴上的对齐方式

justifycontent:'flex-start'

},

效果:
IOS React Native FlexBox详解及实例

flex-end:伸缩项目向一行的结束位置靠齐

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置子项目在主轴上的对齐方式

justifycontent:'flex-end'

},

效果:
IOS React Native FlexBox详解及实例

center:伸缩项目向一行的中间位置靠齐

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置子项目在主轴上的对齐方式

justifycontent:'center'

},

效果:
IOS React Native FlexBox详解及实例

space-between:两端对齐,项目之间的间隔都相等

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置子项目在主轴上的对齐方式

justifycontent:'space-between'

},

效果:
IOS React Native FlexBox详解及实例

space-around:伸缩项目会平均分布在行内,两端保留一半的空间

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置子项目在主轴上的对齐方式

justifycontent:'space-around'

},

效果:
IOS React Native FlexBox详解及实例

alignitems(定义项目在交叉轴上如何对齐,可以把它看成侧轴(垂直于主轴)的对齐方式)flex-start(默认):侧轴轴的起点对齐

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置项目在侧轴上如何对齐

alignitems:'flex-start'

},

效果:
IOS React Native FlexBox详解及实例

flex-end:

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置项目在侧轴上如何对齐

alignitems:'flex-end'

},

效果:
IOS React Native FlexBox详解及实例

center:侧轴的中点对齐

?

1

2

3

4

5

6

7
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置项目在侧轴上如何对齐

alignitems:'center'

},

效果:
IOS React Native FlexBox详解及实例

stretch(默认):如果项目没有设置高度或设置为 auto,将占满整个容器高度

?

1

2

3

4

5

6

7

8
container: {

backgroundcolor:'blue',

注释掉高度

// height:dimensions.get('window').height,

// width:dimensions.get('window').width,

// 设置项目在侧轴上如何对齐

alignitems:'stretch'

},

效果:
IOS React Native FlexBox详解及实例

flexwrap(默认情况下,项目都排在一条轴线上,flex-wrap属性定义如果一条轴线排不下,如何换行)nowrap(默认):不换行

?

1

2

3

4

5

6

7

8

9
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置主轴方向

flexdirection:'row',

// 设置换行的方式

flexwrap:'nowrap'

},

效果:
IOS React Native FlexBox详解及实例

wrap:换行,第一行在上方

?

1

2

3

4

5

6

7

8

9
container: {

backgroundcolor:'blue',

height:dimensions.get('window').height,

width:dimensions.get('window').width,

// 设置主轴方向

flexdirection:'row',

// 设置换行的方式

flexwrap:'wrap'

},

效果:
IOS React Native FlexBox详解及实例

flexbox 常用元素属性flex(flex-grow、flex-shrink、flex-basis三个属性的缩写,第二个参数和第三个参数是可选参数):默认值为 "0 1 auto"

宽度 = 弹性宽度 * (flexgrow / sum(flexgorw))(重要)

先来做一下实验,看看flex到底是干嘛的,首先,我们先初始化一个新视图,便于理解

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22
// 入口

export default class testrn extends component {

render() {

return (

<view style={styles.container}>

<view style={{backgroundcolor:'red', height:60, width:60}}></view>

<view style={{backgroundcolor:'green', height:60, width:60}}></view>

<view style={{backgroundcolor:'yellow', height:60, width:60}}></view>

</view>

);

}

}

// 样式

const styles = stylesheet.create({

container: {

backgroundcolor:'blue',

flex:1,

// 设置主轴方向为水平,起点在左

flexdirection:'row'

},

});

效果:
IOS React Native FlexBox详解及实例

现在我们给红色项目设置 flex 为1,可以看到红色项目的宽度填充了除去 绿色项目和黄色项目 的部分
<view style={{backgroundcolor:'red', height:60, width:60, flex:1}}></view>

效果:
IOS React Native FlexBox详解及实例

接着再给绿色项目也设置 flex 为1,可以看到红色项目和绿色项目填充了 除黄色项目 的部分,并且红色和绿色项目各占剩下空间的一半
<view style={{backgroundcolor:'red', height:60, width:60, flex:1}}></view>

<view style={{backgroundcolor:'green', height:60, width:60, flex:1}}></view>

效果:
IOS React Native FlexBox详解及实例

现在我们再设置黄色项目的 flex 为2,可以看出,红色和绿色所占的空间和等同于黄色项目,并且红色和绿色平分了除黄色项目以外的空间,现在我们应该能理解上面公式的意思了吧(项目宽度 = 父项目的宽度 * (子项目自身比例 / 所有父项目内子项目的比例))

<view style={{backgroundcolor:'red', height:60, width:60, flex:1}}></view>

<view style={{backgroundcolor:'green', height:60, width:60, flex:1}}></view>

<view style={{backgroundcolor:'yellow', height:60, width:60, flex:3}}></view>

效果:
IOS React Native FlexBox详解及实例

但是不知道各位发现了没有,虽然我们每个子项目都同时设置了高度和宽度,但是却只有宽度改变,而高度则一直保持我们设置的状态,是不是 flex属性 只对宽度有效呢?接下来我们来修改下代码,看看是不是真的如我们想象的这样 ———— 这里我们将绿色的高度去掉,可以看出,绿色项目的高度填充了整个父项目的高度

<view style={{backgroundcolor:'red', height:60, width:60, flex:1}}></view>

<view style={{backgroundcolor:'green', width:60, flex:1}}></view>

<view style={{backgroundcolor:'yellow', height:60, width:60, flex:3}}></view>

效果:
IOS React Native FlexBox详解及实例

总结以上的示例,可以看出,不管是否设置子项目的宽度,flex都会忽略宽度,按照上面的公式进行缩放,

如果我们设置了高度,那么 flex 会遵循我们所设置的高度,不去进行拉伸,反之将会对高度进行拉伸

根据 flex 的特性,如果没有设置 view 的尺寸情况下,使用 flex 也可以让 view 占满整个屏幕

container: { backgroundcolor:'blue', flex:1 },

alignself(允许单个项目有与其它项目不一样的对齐方式,可覆盖 align-items属性)auto(默认):继承父元素的alignitems属性,如果没有则切换为stretch
subviewstyle2: { backgroundcolor:'yellow', height:60, width:60, alignself:'auto' },

效果:
IOS React Native FlexBox详解及实例

flex-start:项目从侧轴的起点开始
subviewstyle2: { backgroundcolor:'yellow', height:60, width:60, alignself:'flex-start' },

效果:
IOS React Native FlexBox详解及实例

flex-end:项目从侧轴的终点开始
subviewstyle2: { backgroundcolor:'yellow', height:60, width:60, alignself:'flex-end' },

效果:
IOS React Native FlexBox详解及实例

center:项目以侧轴的中心为参照
subviewstyle2: { backgroundcolor:'yellow', height:60, width:60, alignself:'center' },

效果:
IOS React Native FlexBox详解及实例

stretch
subviewstyle2: { backgroundcolor:'yellow', height:60, width:60, alignself:'stretch' },

效果:
IOS React Native FlexBox详解及实例

我们 flexbox 的使用就先简单介绍到这里,在后续的文章中,会在实际的开发场景中带大家更多更细致地讲解 flexbox,如果你觉得哪里写得不好或者有误,麻烦留言或者用邮箱的方式联系我,当然遇到问题也可以,最后如果喜欢我的文章,还请点个赞并关注,读者的肯定是对我们笔者最大的鼓励,谢谢!

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 IOS React Native FlexBox详解及实例 https://www.kuaiidc.com/91516.html

相关文章

发表评论
暂无评论