简述RN中Flex布局,有何属性

2021-02-23 09:04发布

2条回答
思禹小姐姐y
2楼 · 2021-02-23 09:20

Flexbox是Flexible Box的缩写,意为'弹性布局',它为盒状模型提供了很大的灵活性,让任何一个容器都可以指定为Flex布局。

使用Flex布局的元素,称为Flex容器(flex Container),简称'容器'。它的所有子元素自动成为容器的成员,称为Flex项目(flex Item)


我的网名不再改
3楼 · 2021-02-24 13:53

Flex

是CSS3中的一种新的布局模式,是可以自动调整子元素的高和宽,来很好的填充任何不同屏幕大小的显示设备中的可用显示空间,收缩内容防止内容溢出,确保元素拥有恰当的行为的布局方式。

  • flex的主要概念

  • 1、容器 和 子项目

    • 容器的属性 和成员的属性(这个一定要弄清楚,不能瞎用,否则是浪费时间)

  • 2、主轴 和 侧轴

    • 主轴默认的方向是水平

    • 容器使用主轴的方向

    • 主轴和侧轴是垂直关系

    • 当你改变主轴方向为垂直的时候,想要成员水平居中,这时应该设置侧轴的属性align-items:center

image

  • 3、RN中flex的属性

属性名取值描述
flexDirectionrow, row-reverse, column, column-reverse对应 CSS flex-direction 属性,默认为column
flexWrapwrap, nowrap对应 CSS flex-wrap 属性,但阉割了 wrap-reverse 取值
justifyContentflex-start, flex-end, center, space-between, space-around对应 CSS justify-content 属性,但阉割了 stretch 取值。
alignItemsflex-start, flex-end, center, stretch,baseline对应 CSS align-items 属性。
alignContentflex-start, flex-end, center, stretch, space-between, space-around对应 CSS align-items 属性。
flexnumber对应 CSS flex 属性,但只能为正整数值才会具有弹性
alignSelfauto, flex-start, flex-end, center, stretch,baseline对应 CSS align-self 属性
flexGrownumber对应 CSS flex-grow 属性
flexShrinknumber对应 CSS flex-shrink 属性
flexBasisnumber对应 CSS flex-basis 属性
  • 4、复杂的flex应用

    • 三栏布局

    • 全局布局

    • 悬挂式布局

    • 水平垂直居中

    • 平分等分布

  • 5、 flex的优缺点

  • 优点:对于某些复杂的布局很容易实现

  • 缺点:兼容性,不能兼容IE9及以下浏览器,移动端都能支持
    image

与web的不同

  • 1、StyleSheet.create来集中定义组件的样式,然后通过style属性来实现。驼峰式的写法,作为对象让移动端浏览器解析。长度不用加单位“px”,字符串比如色值需要加引号写成字符串

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
  welcome: {
    fontSize: 20,
    textAlign: 'center',
    margin: 10,
  },
  instructions: {
    textAlign: 'center',
    color: '#333333',
    marginBottom: 5,
  },
});12345678910111213141516171819
  • 2、具有组合性。样式组合是数组形式,web是字符串 空格隔开

1
  • 3、具有覆盖性。

    • RN属性在使用数组对象样式时,如果有两个对象的样式属性相同,RN会默认选择最后一个。

    • 继承时的覆盖,只有最近原则和最直接原则。

    • 没有优先级思想。因为不需要id,class之类的所以没有优先级。

  • 4、支持条件性。RN支持条件性样式

1
  • 5、具有传递性。RN支持样式传递
    在调用组件的时候,可将样式作为参数进行传递。View.propTypes.style和Text.propTypes.style.

propTypes:{
    style:View.propTypes.style,
    textStyle:Text.propTypes.style
}
用的时候:
123456
  • 6、具有部分继承性

    • 样式的继承只存在于Text元素内的Text元素,换句话说是Text元素里面的Text元素存在继承;继承的规则是子Text元素继承祖先Text和父Text元素的样式整合后的样式。

    • 包裹在View元素中的Text表现为block,可以设置margin和padding的各种属性;包裹在Text元素中的Text表现为inline元素,不能设置其marginTop和marginBottom, padding等用于block元素的属性

  • 7、布局样式的不同

    • 没有的属性order、flex-flow

    • RN的flex布局默认为column布局,css的默认为row布局

    • view 相当于web中的

      ,会占容器100%的宽度,不能用fontSize属性

  • 8、position属性只有absolute和relative,不能用zIndex。

    • 在RN开发中,决定用什么布局的是由child来决定的,React Native中的position默认为relative,相对于 上一个兄弟节点

    • React Native中的position默认为relative,所以绝对定位总是相对于父节点的


相关问题推荐

  • 回答 120

    相对前几年来说,要高上不少了,毕竟入行的人也是越来越多了,基础的工作对应想要参与的人群基数越来越大,但是对于高端人才的需求还是很多,人才还是相对稀缺性的。所以,想要学web或者其他技术也一样,别等,别观望。web前端就业方向特别多包括web前端开发...

  • 回答 25

    相对定位和绝对定位是定位的两种表现形式,区别如下:一、主体不同1、相对定位:是设置为相对定位的元素框会偏移某个距离。2、绝对定位:absolute 脱离文档流,通过 top,bottom,left,right 定位。二、特点不同1、相对定位:在使用相对定位时,无论是否进行移...

  • 抓包是什么意思?2020-04-01 17:36
    回答 7
    已采纳

    抓包(packet capture)就是将网络传输发送与接收的数据包进行截获、重发、编辑、转存等操作,也用来检查网络安全。抓包也经常被用来进行数据截取等。抓包可以通过抓包工具来查看网络数据包内容。通过对抓获的数据包进行分析,可以得到有用的信息。目前流行的...

  • 回答 89

    常用的前端框架有Bootstrap框架、React框架、Vue框架、Angular框架、Foundation框架等等

  • 回答 65
    已采纳

    前端是目的就业前景非常不错的一个计算机技术,但是自学的话还是有一定难度的,网络上自学是碎片化的,同时互联网技术跟新换代快,自己的话比较吃力也学习不到最新的技术。

  • SSR 是什么意思?2020-03-20 18:56
    回答 6

    SSR就是一台服务器,可以利用 SSR 在远程的服务器上配置 SSR,使其能够成为 SSR 节点,这样本地电脑或者其它设备利用 SSR 节点实现 VPN 或者远程上网及游戏加速等方面。ShadowsocksR(简称 SSR)是 Shadowsocks 分支,在 Shadowsocks 的基础上增加了一些数据...

  • 回答 11

    1、代码判断xAxis: {type: 'time',splitLine: {show: false},interval: 3600, // 设置x轴时间间隔axisLabel: {formatter: function(value, index) {return liangTools.unix2hm(value)}}},首先要把xAxis 显示类型设置成time,然后设置对应X轴......

  • 回答 52
    已采纳

    计算机培训方向比较多,建议找适合自己的方向选择培训编程类:JAVA、WEB、Python、C/C++、C#等测试类:软件测试运维类:云计算、网络安全设计类:UI设计、3D建模等

  • 回答 8

    HTML5 + CSS + JavaScript 开发 跨平台重用代码 

  • 回答 4

    采用rem单位自动响应,并提供独有栅格化系统快速定义宽高、边距节省css代码量,同时总结各大型移动端网页,提供一套ui颜色搭配规范,尺寸规范,字体规范等。

  • 回答 10

    iView UI、ioni、SUI

  • 回答 6

     jQTouch 

  • 回答 4

    如果只是普通的移动端用vue react 或者dva 如果是要编译成小程序什么的或者混生 就用uni-app(对应vue语法)taro(对应react) 或者纯原生 这个没有限制的,自己怎么舒服怎么来

  • 回答 4

    因为可以运用在网页和小程序的开饭中,而且开源,用着便宜,企业都很喜欢

  • 回答 10

    一、Visual Studio Code下载地址:https://code.visualstudio.com/微软在2015年4月30日Build 开发者大会上正式宣布了 Visual Studio Code 项目:一个运行于 Mac OS X、Windows和 Linux 之上的,针对于编写现代 Web 和云应用的跨平台源代码编辑器。Visual Stud...

  • 回答 9

    jQuery自带淡入淡出效果 https://www.w3school.com.cn/jquery/jquery_fade.asp 看看这个 

没有解决我的问题,去提问