从零学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 ...
随机推荐
- Wamp PHP 安装各种拓展
安装redis 下载dll文件地址:http://pecl.php.net/package/redis 下载对应版本nginx:NTS apache:TS 文件放在php的ext目录下 php.ini ...
- vue多页面项目配置
全局配置 打开 ~\build\webpack.base.conf.js ,找到entry,添加多入口 entry: { main: './src/main.js', main2: './src/ma ...
- Hackerrank--Stock Maximize(DP Practice)
题目链接 Your algorithms have become so good at predicting the market that you now know what the share p ...
- springmvc 使用了登录拦截器之后静态资源还是会被拦截的处理办法
解决办法 在拦截器的配置里加上静态资源的处理 参考https://www.jb51.net/article/103704.htm
- Eclipse-搭建springboot项目报错
Eclipse Maven pom报错: org.apache.maven.archiver.MavenArchiver.getManifest(org.apache.maven.project.Ma ...
- 查询单表菜单是,sql
START WITH CONNECT BY PRIOR这个语法主要用于查询数据包中的树型结构关系.先看下原始数据时怎么样的吧! 表中第一行1001是1002的父节点,而第二行1002又是1003的父节 ...
- curl应用大法
curl -s -S -k --max-redirs 5 -m 60 --connect-timeout 60 -w "\n\n%{time_namelookup}|%{time_conn ...
- LintCode 合并二维数组
合并两个排序的整数数组A和B变成一个新的数组. 样例 给出A=[1,2,3,4],B=[2,4,5,6],返回 [1,2,2,3,4,4,5,6] 之前想的是用剑指offer里替换空格那种方法 但是把 ...
- [运维]VMware vSphere介绍 标签: 运维 2017-04-21 19:48 532人阅读 评论(17)
大部分的程序员,应该是使用过vmware workstation的,我们用这款软件来创建虚拟机,满足我们学习或者工作的一些问题,今天介绍的是vmware家的另一款,不算是软件,比软件范围更大,VMwa ...
- Redis 源码学习之 Redis 事务Nosql
Redis事务提供了一种将多个命令请求打包,然后一次性.按照顺序地执行多个命令的机制,并且在事务执行的期间,服务器不会中断事务而去执行其他不在事务中的命令请求,它会把事务中所有的命令都执行完毕才会去执 ...