首页 web前端 html教程 React Native 之 flexbox 布局详解篇 (清晰明了)_html/css_WEB-ITnose

React Native 之 flexbox 布局详解篇 (清晰明了)_html/css_WEB-ITnose

Jun 24, 2016 am 11:16 AM

回复『 1024 』你懂的!

阅读本文大约需要5分钟

本文详情

本文讲解React Native中的布局,该布局用CSS的flex布局,掌握了这个布局对后面RN应用的开发用途非常之大。本文由 showCar 投稿(点击 阅读原文 )。文章地址: http://blog.csdn.net/u014486880

1.常用属性

RN的flexbox主要有以下几个属性alignItems,alignSelf,flex,flexDirection,flexWrap,justifyContent。

2.flexDirection

该属性用于指定主轴的方向。即指定子view的布局方向。它有两个值可设置。

  • row:横向布局。

  • column:纵向布局。

这个属性很简单,先看row的代码段:

一个View里有四个小View,小View的底色是黑的,看下效果图:  可以看到,四个view横向的进行布局。那改成column呢,样式修改如下: 看下效果图: 

就是纵向布局。

3.alignItems

用于定义子组件在垂直方向上的对齐方式。有四个属性可设置:flex-start,flex-end,center,stretch。

  • flex-start:与父组件的顶部对齐。

  • flex-end:与父组件的底部对齐。

  • center:处于父容器的中间位置。

  • stretch:竖直上填充整个容器。

首先来看下flex-start,顺便改了下子组件的颜色,代码如下: 看下效果图: 

就是和父容器顶部对齐。

看下flex-end属性,代码就不贴出来了,只要改alignItems属性就好了。效果图如下:

可以看到,和底部对齐了。  再看下center,这个可以说是用的最多的属性,它会让子组件位于父容器的中间位置,看下效果图: 

stretch就是竖直填充,前提是子组件没有设置height属性。看下效果图: 

4.justifyContent

有竖直就水平。justifyContent和alignItems是相对的。它有五个属性可以设置,分别是flex-start,flex-end,center,space-between,space-around。 

  • flex-start:伸缩项目与父容器左端靠齐。

  • flex-end:与父容器右端靠齐。

  • center:水平居中。

  • space-between:第一个子组件位于父容器左端,最后一个子组件位于父容器最右端。然后平均分配在父容器水平方向上。

  • space-around:所有子组件平均分配在父容器的水平方向上,左右都有留空隙。

先看水平居中(center)的,先看下代码:

父容器设置了justifyContent:’center’属性,所以理论上子组件应该会水平剧中,来看下是否正确。如下: 

justifyContent:’flex-start’,水平居左: 

justifyContent:’flex-end’,水平居右: 

这些都挺简单的,来看下space-between和space-around的区别,先看下space-between的效果图: 

可以看到它左右都不留空隙。均匀分布。  再看下space-around的效果图:  它左右都留有空隙,是平均的位于整个界面的水平方向上。

5.alignSelf

该属性用来设置单独组件的竖直对齐方式,与alignItem有点像。有五个属性可以设置,auto,flex-start,flex-end,center,streth。 

  • auto:按照自身设置的宽高来显示,如果没设置,效果跟streth一样。

  • flex-start:与父容器顶部对齐。

  • flex-end:与父容器底部对齐。

  • center:位于垂直位置。

  • streth:垂直拉伸。

这个用法跟上面的很像,只是它用于单个组件,如本例子的子View中,看下代码: 以上几个子View设置了不同的样式 ,看下效果图:

看到了,flex-start就是顶部对齐,flex-end就是与底部对齐。第三个View是streth,垂直拉伸了。第四个View是auto,因为设置了高度,所以显示如图所示。没有显示center,但它的效果可想而知,就不再演示啦。

6.flex

flex指设置伸缩项目的伸缩样式,可以把它类比成android中的weight属性。  看一个代码就清楚它的用法了。 效果图如下: 

可以看到,flex为2的组件宽度为flex为1宽度的两倍,flex为4组件宽度则为flex为1的组件宽度的4倍。

7.flexWrap

其实这些属性都是CSS原有的属性,只是RN只支持了部分的属性。flexWrap用于设置是否可换行,有两个属性可设置nowrap和wrap。

  • nowrap:即使空间不够也不换行。

  • wrap:空间不够的话自动换行。

如设置成wrap时,空间不够效果图如下:

第四个放不下,就换行了。 

8.再说两句

本文对于flex布局做了详细说明,而且应该算是图文搭配,解释的非常清晰明了,感谢投稿者~

本公众号欢迎大家投稿,如果你希望你的文章可以被更多人看到,直接将md、doc等格式的文章到我邮箱即可( 781931404@qq.com ),也可以加我QQ/微信( 781931404 )好友,需要注明(投稿),谢谢。

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

> gt;的目的是什么 元素? > gt;的目的是什么 元素? Mar 21, 2025 pm 12:34 PM

本文讨论了HTML< Progress>元素,其目的,样式和与< meter>元素。主要重点是使用< progress>为了完成任务和LT;仪表>对于stati

< datalist>的目的是什么。 元素? < datalist>的目的是什么。 元素? Mar 21, 2025 pm 12:33 PM

本文讨论了html< datalist>元素,通过提供自动完整建议,改善用户体验并减少错误来增强表格。Character计数:159

< meter>的目的是什么。 元素? < meter>的目的是什么。 元素? Mar 21, 2025 pm 12:35 PM

本文讨论了HTML< meter>元素,用于在一个范围内显示标量或分数值及其在Web开发中的常见应用。它区分了< meter>从< progress>和前

HTML容易为初学者学习吗? HTML容易为初学者学习吗? Apr 07, 2025 am 12:11 AM

HTML适合初学者学习,因为它简单易学且能快速看到成果。1)HTML的学习曲线平缓,易于上手。2)只需掌握基本标签即可开始创建网页。3)灵活性高,可与CSS和JavaScript结合使用。4)丰富的学习资源和现代工具支持学习过程。

视口元标签是什么?为什么对响应式设计很重要? 视口元标签是什么?为什么对响应式设计很重要? Mar 20, 2025 pm 05:56 PM

本文讨论了视口元标签,这对于移动设备上的响应式Web设计至关重要。它解释了如何正确使用确保最佳的内容缩放和用户交互,而滥用可能会导致设计和可访问性问题。

< iframe>的目的是什么。 标签?使用时的安全考虑是什么? < iframe>的目的是什么。 标签?使用时的安全考虑是什么? Mar 20, 2025 pm 06:05 PM

本文讨论了< iframe>将外部内容嵌入网页,其常见用途,安全风险以及诸如对象标签和API等替代方案的目的。

HTML,CSS和JavaScript的角色:核心职责 HTML,CSS和JavaScript的角色:核心职责 Apr 08, 2025 pm 07:05 PM

HTML定义网页结构,CSS负责样式和布局,JavaScript赋予动态交互。三者在网页开发中各司其职,共同构建丰富多彩的网站。

HTML中起始标签的示例是什么? HTML中起始标签的示例是什么? Apr 06, 2025 am 12:04 AM

AnexampleOfAstartingTaginHtmlis,beginSaparagraph.startingTagSareEssentialInhtmlastheyInitiateEllements,defiteTheeTheErtypes,andarecrucialforsstructuringwebpages wepages webpages andConstructingthedom。

See all articles