从零学React Native之06flexbox布局
前面我们接触了好多React Native代码, 并没有介绍RN中的组件具体是如何布局的,这一篇文章,重点介绍下flexbox布局。
什么是flexbox布局
React中引入了flexbox概念,flexbox是属于web前端领域CSS的一种布局方案,是2009年W3C提出了一种新的布局方案,可以简便、完整、响应式地实现各种页面布局。你可以简单的理解为flexbox是CSS领域类似Android中 LinearLayout的一种布局,但是要比 LinearLayout要强大的多。
React Native中对Web端的FlexBox进行了阉割,以用来适应移动设备。
RN利用flexBox模型布局, 也就是在手机屏幕上对组件进行排列.利用flexBox模型,开发者可以开发出动态宽高的自适应的UI布局。
我们前面介绍过View,Text等组件的一些属性设置了,RN强大的UI布局能力主要是通过各个不同组件的样式(style)属性中的各个键的设置来实现的。大部分组件的style都支持flexbox布局。
下面就是我们常见的布局的写法:
...
class AwesomeProject extends Component {
render() {
return (
<View style={styles.container}> //根View
<View style={styles.test1}/> // 子View
<View style={styles.test2}/> // 子View
</View>
);
}
}
const styles = StyleSheet.create({
container: { //根View样式
flex: 1,
backgroundColor: '#F5FCFF',
},
test1:{ // 子View样式
width:360,
height:60,
backgroundColor:'red'
},
test2:{ //子View样式
width:40,
height:40,
backgroundColor:'blue'
}
});
flexbox中的样式主要有以下几类:
1. 位置及宽、高相关的样式键
2. 容器属性,决定子组件排列规则的键
3. 元素属性,决定组件显示规则的键
4. 边框、空隙与填充
位置及宽、高相关的样式键
位置主要是postion、 top 、bottom、 left、 right 几个属性
首先讨论position键。它是字符串类型,取值包括 relative(默认)或者absolute,表示当前描述的位置是相对定位还是绝对定位.
top 、bottom、 left、 right 四个键是数值类型.
当position的值为absolute时,描述就指的是当前组件的位置距离父组件最上(下、左、右)有多少pt.
当position的键为relative时,不可以使用bottom和right,top和left键默认值为0.top和left表示当前组件距离上一个同级组件的最上(左)有多少pt
宽高包括: width、height、maxHeight、maxWidth、minHeight、minWidth 都是数值类型,因为使用flexbox布局,组件的款和高是可以动态改变的,所以可以设置宽和高的最大和最小值
容器属性,决定子组件排列规则的键
flexDirection:
flexDirection键决定了组件内部的子组件是如何排列的, 取值可以为: row,column,类似Android中LinearLayout的orientation属性.
row:横向排列,主轴为水平方向;
column:竖直排列,主轴为垂直方向。
flexWrap:
flexWrap字符串类型,可选wrap和nowrap(默认值)
水平或垂直布局时,如果子View放不下,则自动换行, 默认为’nowrap’(不换行)
justifyContent:
设置子布局在主轴方向位置
alignItems:
定义了View组件中所有子组件的对齐规则. 有4种可能的字符串类型的值:
1. flex-start 顶部对齐
2. flex-end 底部对齐
3. center 中部对齐
4. stretch 拉长对齐
元素属性,决定组件显示规则的键
flex:
权重,类似Android中weight。
flex键的类型是数值,取值为0或者1,默认值是0,当它的值为1时,子组件将自动缩放以适应父组件剩下的空白空间.
开发者使用flex键时一定要小心,它的自动缩放意味着不仅可以改变自己的宽、高与位置,还可以通过挤压改变与它同级的其他组件的位置。
设置了flex:1的组件不是只能扩展,如果同级别固定宽高的组件在执行宽高增加了,那么设置flex:1的组件就会缩小来适应同级组件的宽和高变化.
alignSelf:
alignSelf键有5种可能的字符串类型值:auto、flex-start、flex-end、center、stretch.其用途是让组件忽略它的父组件样式中的alignItems的取值,而对该组件使用alignSelf键对应的规则。当它取值为auto时,表示使用父View组件的alignItems值。
边框、空隙与填充
边框borderWith, 填充 padding, 组件空隙margin, 接触过Android的同学看一眼下面的图应该就了解了。
组件多样式声明与动态样式声明
组件可以有多种样式,可以把相同的样式抽取出去,方便复用。
写法如下:
style={[styles.container,styles.aStyle,styles.bStyle]}
在多种样式中,如果对某一个键有重复定义,那么后面的样式定义的键将覆盖前面的.
在UI设计中,有些组件的样式在应用运行中是需要改变的,这时我们需要直接在描述组件的JSX代码中写入需要变化的样式.
示例代码:
...
<Text
onPress={this.onTextPress}
style={[styles.aStyle,{color:this.state.appColor1}]}>
...
...
onTextPress(){
this.setState({
appColor1:'red'
})
}
更多精彩请关注微信公众账号likeDev,公众账号名称:爱上Android。
从零学React Native之06flexbox布局的更多相关文章
- 从零学React Native之11 TextInput
TextInput 组件是用来通过键盘输入文字,可以使用View组件和Text组件样式,没有自己特定的样式. 与Text组件类似,TextInput组件内部的元素不再使用FlexBox布局,而采用文本 ...
- 从零学React Native之13 持久化存储
数据持久化就是指应用程序将某些数据存储在手机存储空间中. 借助native存储 这种方式不言而喻,就是把内容传递给native层,通过原生API存储,详见从零学React Native之05混合开发 ...
- 从零学React Native之03页面导航
之前我们介绍了RN相关的知识: 是时候了解React Native了 从零学React Native之01创建第一个程序 从零学React Native之02状态机 本篇主要介绍页面导航 上一篇文章给 ...
- 从零学React Native之02状态机
本篇文章首发于简书 欢迎关注 之前我们介绍了RN相关的知识: 是时候了解React Native了 从零学React Native之01创建第一个程序 本篇文章主要介绍下下面的知识: 1.简单界面的搭 ...
- 从零学React Native之10Text
在React Native开发中,所有需要显示的字符串文本都需要放置在Text或者Text的子组件中.虽然在之前的文章中多次使用了Text组件,但是Text组件还是值得专门学习的, 并没有想象中的那么 ...
- 从零学React Native之07View
View 组件是React Native最基本的组件.绝大部分其他React Native 组件. View组件的颜色和边框 backgroundColor 键用来指定颜色. RN 0.19版本开始, ...
- 从零学React Native之04自定义对话框
本篇主要介绍: 1. 自定义组件 2. Alert 对话框 自定义对话框 之前的我都是利用React Native提供的基础组件对它们进行排列组合, 其实自定义也很简单, 我们还是拿上一篇文章的例子进 ...
- 从零学React Native之14 网络请求
通过HTTP或者HTTPS协议与网络侧服务器交换数据是移动应用中常见的通信方式. node-fetch是RN推荐的请求方式. React Native框架在初始化项目时, 引入了node-fetch包 ...
- 从零学React Native之12 组件的生命周期
一个React Native组件从它被加载,到最终被卸载会经历一个完整的生命周期.所谓生命周期,就是一个对象从开始生成到最后消亡所经历的状态,理解生命周期,是合理开发的关键. ES6语法和之前的ES5 ...
随机推荐
- Objective-C头文件导出工具class-dump
首先,这个工具是开源的.作者网站:http://stevenygard.com/projects/class-dump/ 用途: 分析库文件或可执行文件,得到Objective-C类和部分C结构体的信 ...
- MySQL--python关联MySQL、练习题
1.python关联MySQL pymysql: 安装:pip3 install pymysql 1.0:连接到数据库中 import pymysql conn = pymysql.connect( ...
- case 和decode的区别
区别: decode是pl/sql语法,只能在oracle中使用,case when是标准SQL的语法,哪儿都能用,也就是说移植性更强. decode像是case when的精简版,当要实现的功能比较 ...
- apache添加虚拟主机(windows下)
1.打开Apache的目录下的 D:\Web\Apache\conf\httpd.conf 允许虚拟,启动虚拟配置文件 2.配置虚拟主机 打开 D:\Web\Apache\conf\extra\ht ...
- 【python之路15】深浅拷贝及函数
一.集合数据类型(set):无序不重复的集合,交集.并集等功能 二.三元运算符 三.深浅拷贝 1)字符串和数字:深浅内存地址都一样 2)其他:浅拷贝:仅复制最外面第一层 深拷贝:除了最内层其他均拷贝 ...
- C# 通过URL得到图片的问题
第一个方法在读取某些图片会报错 public static Image get_Fill_image(string url) { var image = new Image(); image.Sour ...
- BP神经网络分类应用
DNA序列分类 作为研究DNA序列结构的尝试,提出以下对序列集合进行分类的问题:有20个已知类别的人工制造序列,其中序列标号1-10为A类,11-20为B类.请从中提取特征,构造分类方法,并用这些已 ...
- DIV+CSS网页布局常用的一些基础知识整理
CSS命名规范 一.文件命名规范 全局样式:global.css: 框架布局:layout.css: 字体样式:font.css: 链接样式:link.css: 打印样式:print.css: 二.常 ...
- Redis-cli 命令不能用
bash: redis-cli: command not found... 环境: Linux7.X 在运行redis-cli命令的时候提示错误: 解决方案: 1. wget http://downl ...
- JQuery--val()、html()、text()
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...