IOS React Native FlexBox详解及实例

2020-01-18 17:08:26于海丽

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 就是用来解决 父盒子 和 子盒子 之间的约束关系,如下图

React,Native之FlexBox,Native,FlexBox详解,FlexBox实例

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

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

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

React,Native之FlexBox,Native,FlexBox详解,FlexBox实例

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

React,Native之FlexBox,Native,FlexBox详解,FlexBox实例