前言

弹性盒模型(The Flexible Box Module),又叫FlexBox,意为“弹性布局”,旨在通过弹性的方式来对齐和分布容器中内容的空间,使其能适应不同的屏幕,为盒装模型提供最大的灵活性。

FlexBox在大部分情况下都是处理Item在Container中位置和尺寸的关系。

FlexBox在布局中能解决很多问题,如浮动布局、屏幕适配、水平垂直居中、自动分配宽度等。

FlexBox布局属性

flexDirection主轴方向:

flexDirection属性用来设置主轴的方向,即视图中子控件的排列顺序,有如下几种选项:

  • column(默认值):子控件从上向下排列;
  • column-reverse:子控件从下向上排列;
  • row:子控件从左向右排列;
  • row-reverse:子控件从右向左排列。

justifyContent对齐方式:

justifyContent属性用来设置伸缩项在主轴线的对齐方式,有如下几种选项:

  • flex-start(默认值):向主轴方向的起始端靠齐;
  • flex-end:向主轴方向的结尾端靠齐;
  • center:向主轴中间靠齐;
  • space-between:两段靠齐,项之间间隔相等,主轴两段没有空隙;
  • space-around:项平均的分布在主轴上,每个项的两段都有空隙。

alignItems侧轴对齐方式:

alignItems属性用来设置伸缩项在侧轴上的对齐方式(侧轴永远垂直于主轴),有如下几种选项:

  • stretch(默认值):如果没有设置项的高度或设置为auto,则项将占满侧轴;
  • flex-start:向侧轴方向的起始端靠齐;
  • flex-end:向侧轴方向的末尾端靠齐;
  • center:向侧轴的中间靠齐。

flexWrap流式布局样式:

flexWrap属性用来设置流式布局(当所有项不能显示在一行中时,换行显示)的样式,有如下几种选项:

  • nowrap(默认值):不换行;
  • wrap:换行,新行在旧行下方;
  • wrap-reverse:换行,新行在旧行上方。

注意:flexWrap属性在iOS上可以正常设置,但在Android上如果不加额外的设置,则只会显示第一行,解决方法是添加style:alignItems: ’flex-start’

FlexBox元素属性

flex元素比重:

flex属性是flex-grow、flex-shrink和flex-basis三个属性的组合体,其中后两个属性是可选属性。三个属性具体解释如下:

  • flex-grow:元素占当前容器中的弹性宽度的比重,默认是0;
  • flex-shrink:缩小元素的宽度,值越大缩的越小,默认值是1;
  • flex-bisis:相当于CSS中的width属性,默认值是auto。

元素在容器中的宽度/高度的计算公式:宽/高度 = 弹性宽度 * (flow-grow / sum(flow-grow));

alignSelf

alignSelf属性允许单个元素有与其他元素不一样的对齐方式,有如下几种选项:

  • auto(默认值):集成父容器的对齐方式,如果没有父容器,则相当于stretch;
  • flex-start:当前元素向父容器的起始端靠齐;
  • flex-end:当前元素向父容器的结尾端靠齐;
  • center:当前元素向父容器的中间靠齐;
  • stretch:当前元素拉伸铺满父容器。

注意:alignSelf属性相当于将父容器的alignItems属性进行了覆盖。

FlexBox其他方法

获取当前屏幕的宽度(高度、分辨率使用同样方法获取):

let Dimensions = require('Dimensions');
let width = Dimensions.get('window').width;

获取当前屏幕的宽度、高度、分辨率:

let Dimensions = require('Dimensions');
let {width, height, scale} = Dimensions.get('window');

补充参考

Flex布局教程 - 语法篇

Flex布局教程 - 实例篇

【RN - 基础】之FlexBox弹性布局的更多相关文章

  1. CSS3中的Flexbox弹性布局(一)

    CSS3引入了一种新的布局模式——Flexbox布局,即伸缩布局盒模型(Flexible Box),用来提供一个更加有效的方式制定.调整和分布一个容器里项目布局,即使它们的大小是未知或者动态的,这里简 ...

  2. css3 FlexBox 弹性布局

    Flex 弹性布局 这个是css3中新添加的内容,现在已经支持所有的浏览器,利用Flex布局,可以简便.完整.响应式地实现各种页面布局. 注意:在设置 flex 后,子元素的flaot ,clear, ...

  3. java基础之Flex弹性布局、JSP错误处理以及Log4J

    一.Flex弹性布局 1.产生的比较晚,目前在移动网页开发中可以使用,而且逐渐成为主流. 在桌面网页开发中使用的比较少(主要是桌面浏览器的兼容性问题更加严重) 2.开启方法: 在容器标签上加上 dis ...

  4. CSS3中的Flexbox弹性布局(二)

    flexbox详解 flexbox的出现是为了解决复杂的web布局,因为这种布局方式很灵活.容器的子元素可以任意方向进行排列.此属性目前处于非正式标准. flex布局模型不同于块和内联模型布局,块和内 ...

  5. Flexbox弹性布局

    Flexbox,一种CSS3的布局模式,也叫做弹性盒子模型,用来为盒装模型提供最大的灵活性.最新版本兼容IE11+.firefox.safari.chrome.opera及移动端,但移动端ios7.1 ...

  6. css flexbox 弹性布局

    flexbox 即css flexible box layout. ie9及以下不支持flexbox. flex详细规范(https://www.w3.org/TR/css-flexbox/) 为什么 ...

  7. Flexbox弹性布局,更优雅的布局

    Flexbox,更优雅的布局 Flex 布局教程:语法篇 Flex 布局教程:实例篇 2009年,W3C提出了一种新的方案----Flex布局,可以简便.完整.响应式地实现各种页面布局.目前,它已经得 ...

  8. CSS3 flexbox弹性布局实例

    常用例子 1.居中对齐 <!DOCTYPE html> <head> <meta charset="utf-8"> <style type ...

  9. React Native 弹性布局FlexBox

    React Native采用一中全新的布局方式:FlexBox(弹性布局).可以很方便的实现各种复杂布局,是全新的针对web和移动开发布局的一种实现方式. 何为FlexBox? 完整名称为:the f ...

随机推荐

  1. Unity5-ABSystem(四):AssetBundle依赖

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/lodypig/article/detai ...

  2. 【Leetcode 做题学算法周刊】第二期

    首发于微信公众号<前端成长记>,写于 2019.11.05 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 20 ...

  3. (Java) byte[] 和 base64 字符串之间的转换

    import org.apache.commons.codec.binary.Base64; public class UtilHelper { //base64字符串转byte[] public s ...

  4. node 短信接口的调用

    首先安装一下 短信的sdk 依赖 这里使用的是阿里云的短信SDK,在阿里云官网申请 npm install @alicloud/sms-sdk --save 调用 新建个 message.js /** ...

  5. Nginx专题(1):Nginx之反向代理及配置

    摘要:本文从Nginx的概念出发,分别从反向代理的概念.优势.配置代码3个方面介绍了Nginx的特性之一反向代理. 文章来源:宜信技术学院 & 宜信支付结算团队技术分享第一期-宜信支付结算八方 ...

  6. Everything 信息泄露

    google语法: inurl:Diagnostics/index 这个无意间看到别人找到的,其实是everything自带的http服务器功能开启了忘记关,算是管理员自己的疏忽 可以看到开了ever ...

  7. My Eclipse 配置

    设置编码格式 点击Windows → preference → WorkSpace 设置编码格式 点击Windows → preference → General →Appearence → Colo ...

  8. CSPS模拟 55

    没睡醒就考试,蓝绶 考试前我在擦眼镜 好像总也擦不干净? 就像石乐志一样一直地在擦 cbx捅了我几下,好像想说什么? 没睡醒,不理 终于擦完了! 雾草要考试? T1 联 先离散化,再正面上线段树 em ...

  9. 搞清楚 Python 的迭代器、可迭代对象、生成器

    很多伙伴对 Python 的迭代器.可迭代对象.生成器这几个概念有点搞不清楚,我来说说我的理解,希望对需要的朋友有所帮助. 1 迭代器协议 迭代器协议是核心,搞懂了这个,上面的几个概念也就很好理解了. ...

  10. 建议收藏备用:.net core使用QRCoder生成普通二维码和带Logo的二维码详细使用教程,源码已更新至开源模板

    随着互联网越来越生活化,二维码的使用越来越普遍,不论是扫码支付还是扫码关注引流,似乎我们总是离不开二维码,那么很多需要推广的文章或社区想要自己的二维码,那么你是不是需要在网站直接提供给用户呢?很多开发 ...