浅谈React Native Flexbox布局(小结)


Posted in Javascript onJanuary 08, 2018

Flex 是 Flexible Box 的缩写,意为”弹性布局”,用来为盒状模型提供最大的灵活性。

基本概念

采用 Flex 布局的元素,称为 Flex 容器(flex container),简称”容器”。它的所有子元素自动成为容器成员,称为 Flex 项目(flex item),简称”项目”。

浅谈React Native Flexbox布局(小结)

容器默认存在两根轴:水平的主轴(main axis)和垂直的交叉轴(cross axis)。主轴的开始位置(与边框的交叉点)叫做main start,结束位置叫做main end;交叉轴的开始位置叫做cross start,结束位置叫做cross end。

项目默认沿主轴排列。单个项目占据的主轴空间叫做main size,占据的交叉轴空间叫做cross size。

容器的属性

以下6个属性设置在容器上。

  1. flex-direction
  2. flex-wrap
  3. flex-flow
  4. justify-content
  5. align-items
  6. align-content

flex-direction属性

flex-direction属性决定主轴的方向(即项目的排列方向)。

{
 flex-direction: row | row-reverse | column | column-reverse;
}

浅谈React Native Flexbox布局(小结)

它有4个值。

  1. row(默认值):主轴为水平方向,起点在左端
  2. row-reverse:主轴为水平方向,起点在右端
  3. column:主轴为垂直方向,起点在上沿
  4. column-reverse:主轴为垂直方向,起点在下沿

flex-wrap属性

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

浅谈React Native Flexbox布局(小结)

{
 flex-wrap: nowrap | wrap | wrap-reverse;
}

它有三个值。

1)nowrap(默认):不换行。

浅谈React Native Flexbox布局(小结)

2)wrap:换行,第一行在上方。

浅谈React Native Flexbox布局(小结)

3)wrap-reverse:换行,第一行在下方。

浅谈React Native Flexbox布局(小结)

flex-flow

flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。

{
 flex-flow: <flex-direction> || <flex-wrap>;
}

justify-content属性

justify-content属性定义了项目在主轴上的对齐方式。

浅谈React Native Flexbox布局(小结)

它有5个值,具体对齐方式与轴的方向有关。下面假设主轴为从左到右

  1. flex-start(默认值):左对齐
  2. flex-end:右对齐
  3. center: 居中
  4. space-between:两端对齐,项目之间的间隔都相等。
  5. space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍

align-items属性

align-items属性定义项目在交叉轴上如何对齐。

{
 align-items: flex-start | flex-end | center | baseline | stretch;
}

浅谈React Native Flexbox布局(小结)

它有5个值。具体的对齐方式与交叉轴的方向有关,下面假设交叉轴从上到下。

  1. flex-start:交叉轴的起点对齐
  2. flex-end:交叉轴的终点对齐
  3. center:交叉轴的中点对齐
  4. baseline: 项目的第一行文字的基线对齐
  5. stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度

align-content属性

align-content属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用。

{
 align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}

浅谈React Native Flexbox布局(小结)

该属性有6个值

  1. flex-start:与交叉轴的起点对齐
  2. flex-end:与交叉轴的终点对齐
  3. center:与交叉轴的中点对齐
  4. space-between:与交叉轴两端对齐,轴线之间的间隔平均分布
  5. space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍
  6. stretch(默认值):轴线占满整个交叉轴

项目的属性

以下6个属性设置在项目上。

  1. order
  2. flex-grow
  3. flex-shrink
  4. flex-basis
  5. flex
  6. align-self

order属性

order属性定义项目的排列顺序。数值越小,排列越靠前,默认为0。

{
 order: <integer>;
}

浅谈React Native Flexbox布局(小结)

flex-grow属性

flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大

{
 flex-grow: <number>; /* default 0 */
}

浅谈React Native Flexbox布局(小结)

如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话)。如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。

flex-shrink属性

flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。

{
 flex-shrink: <number>; /* default 1 */
}

浅谈React Native Flexbox布局(小结)

如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小。

负值对该属性无效。

flex-basis属性

flex-basis属性定义了在分配多余空间之前,项目占据的主轴空间(main size)。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小。

{
 flex-basis: <length> | auto; /* default auto */
}

它可以设为跟width或height属性一样的值(比如350px),则项目将占据固定空间。

flex属性

flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto。后两个属性可选。

{
 flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
}

该属性有两个快捷值:auto (1 1 auto) 和 none (0 0 auto)。

align-self属性

align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。

{
 align-self: auto | flex-start | flex-end | center | baseline | stretch;
}

浅谈React Native Flexbox布局(小结) 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
50个比较实用jQuery代码段
Sep 18 Javascript
用js来获取上传的文件名纯粹是为了美化而用
Oct 23 Javascript
按钮接受回车事件的三种实现方法
Jun 06 Javascript
自定义函数实现IE7与IE8不兼容js中trim函数的问题
Feb 03 Javascript
JavaScript中0和&quot;&quot;比较引发的问题
May 26 Javascript
js实现符合国情的日期插件详解
Jan 19 Javascript
支持移动端原生js轮播图
Feb 16 Javascript
bootstrap与pagehelper实现分页效果
Dec 29 Javascript
vue登录注册实例详解
Sep 14 Javascript
webpack打包优化的几个方法总结
Feb 10 Javascript
Nuxt.js nuxt-link与router-link的区别说明
Nov 06 Javascript
类和原型的设计模式之复制与委托差异
Jul 07 Javascript
Node.js使用Koa搭建 基础项目
Jan 08 #Javascript
JavaScript体验异步更好的解决办法
Jan 08 #Javascript
探索Vue高阶组件的使用
Jan 08 #Javascript
Vue入门之数据绑定(小结)
Jan 08 #Javascript
浅谈Vue数据绑定的原理
Jan 08 #Javascript
让网站自动生成章节目录索引的多个js代码
Jan 07 #Javascript
JavaScript学习总结(一) ECMAScript、BOM、DOM(核心、浏览器对象模型与文档对象模型)
Jan 07 #Javascript
You might like
PHP中使用glob函数实现一句话删除某个目录下的所有文件
2014/07/22 PHP
PHP实现求两个字符串最长公共子串的方法示例
2017/11/17 PHP
thinkPHP5框架实现基于ajax的分页功能示例
2018/06/12 PHP
PHP的PDO预处理语句与存储过程
2019/01/27 PHP
ExtJS 2.0实用简明教程 之获得ExtJS
2009/04/29 Javascript
模拟电子签章盖章效果的jQuery插件源码
2013/06/24 Javascript
Javascript定义类(class)的三种方法详解
2015/03/13 Javascript
Bootstrap框架动态生成Web页面文章内目录的方法
2016/05/12 Javascript
详解JavaScript节流函数中的Throttle
2016/07/16 Javascript
支持移动端原生js轮播图
2017/02/16 Javascript
AngularJS实现的鼠标拖动画矩形框示例【可兼容IE8】
2019/05/17 Javascript
基于jquery ajax的多文件上传进度条过程解析
2019/09/11 jQuery
layui table 获取分页 limit的方法
2019/09/20 Javascript
js实现课堂随机点名系统
2019/11/21 Javascript
vue 实现click同时传入事件对象和自定义参数
2021/01/29 Vue.js
python将MongoDB里的ObjectId转换为时间戳的方法
2015/03/13 Python
python通过定义一个类实例作为ftp回调方法
2015/05/04 Python
详解Python编程中基本的数学计算使用
2016/02/04 Python
python 划分数据集为训练集和测试集的方法
2018/12/11 Python
windows上安装python3教程以及环境变量配置详解
2019/07/18 Python
Python如何基于smtplib发不同格式的邮件
2019/12/30 Python
pytorch 实现张量tensor,图片,CPU,GPU,数组等的转换
2020/01/13 Python
Bootstrap 学习分享
2012/11/12 HTML / CSS
基于HTML5代码实现折叠菜单附源码下载
2015/11/27 HTML / CSS
音乐学院硕士生的自我评价分享
2013/11/01 职场文书
大学自主招生自荐信
2013/12/16 职场文书
九年级语文教学反思
2014/02/04 职场文书
互联网创业计划书写作技巧攻略
2014/03/23 职场文书
班子四风对照检查材料思想汇报
2014/09/29 职场文书
公务员群众路线心得体会
2014/11/03 职场文书
试用期自我评价范文
2015/03/10 职场文书
学校办公室主任岗位职责
2015/04/01 职场文书
学习心理学心得体会
2016/01/22 职场文书
pycharm2021激活码使用教程(永久激活亲测可用)
2021/03/30 Python
Python 把两层列表展开平铺成一层(5种实现方式)
2021/04/07 Python
用基于python的appium爬取b站直播消费记录
2021/04/17 Python