React-Native 样式、布局、绘制

作者: 250的梦想 | 来源:发表于2017-12-07 10:54 被阅读240次

1,写在前面

在web开发中,以往结构、样式、行为的开发通常是分离的,也就是所谓的“关注点分离(separation of concerns)”,它的意思是,各种技术只负责自己的领域(html、css、js),不要混合在一起,形成耦合。

HTML 语言:负责网页的结构,又称语义层

CSS 语言:负责网页的样式,又称视觉层

JavaScript 语言:负责网页的逻辑和交互,又称逻辑层或交互层

这在往日都是好的实践推荐。但是这几年组件化和模块化开发思维渐行其道(特别是React出来后,打破了这一原则,React的基础组织单元是组件,强制要求把html、css、js写在一起),特性或者功能粒度成为一种软件设计和开发上的选择。

那么,在实际开发中,有没有一种超集可以贯穿三者呢? 有,jsx和typescript就是,jsx与typescript是两个不同的概念,但都是一种语法糖,都是JavaScript的超集合,typescript1.6版本是支持jsx的,在react中会用jsx(write css in js、write “html” in js)来开发组件,React-native是react的扩展,在组件开发上也是用的jsx。

                                                      component in react-native

2,样式

2.1,样式定义

在RN中,并不需要学习什么特殊的语法来定义样式,使用JavaScript来写样式。样式名(属性)基本上遵循的是CSS的命名 和规则(比如后定义覆盖原则、样式表现等),只是按照JS的语法要求,某些样式名需要用驼峰命名法(比如css中的background-color 需写成“backgroundColor”)。

样式的定义有两种方式:

内联方法: style={{color: red}}

样式生成器: : styleSheet.creat({textColor: {color: red}})

2.2,样式用法

在RN中,核心组件都有一个名为style的属性,样式在RN中的应用就是给该属性赋值。属性的值可为JavaScript中的对象({color:red}),或者数组([{color: red}, {color: blue}])。

2.3,样式应用范畴(组件可用样式和识别)

RN中的组件(基础组件、RN中提供的组件)所能应用的样式有一定的范畴,比如color样式不能应用在View组件中。识别哪些组件有哪些可用的样式有两种方法:1,去网上或者官网查。2,调试时打开warn提醒,应用一个样式,如果该组件没有该样式,则会有告警。告警里面会列出该组件所能应用到的样式集合。

3,布局

在React Native中使用flexbox规则来指定某个组件的子元素的布局。Flexbox可以在不同屏幕尺寸上提供一致的布局结构。RN中的Flexbox规则和Web中Css FlexBox基本一致,主要的不同就是flex-direction默认不同,css中默认是水平方向,rn中默认是垂直方向。具体的flexbox布局相关的知识可以参考我之前写的一篇文章《盒模型与布局》

4,绘制

Web中页面的绘制是浏览器器UI后端做的,而在RN中则是交由原生去绘制(例如ios中的UIkits,具体RN和原生的交互和通讯可以参考我之前写的另外一篇文章《React-Native原理解析与通讯机制阐述(Eg:ios)》),这里只做简单的浅析和对比。

4.1,web 页面绘制

                                                4.1.1,webkite解析网页的过程

                                          4.1.2,浏览器的内部过程

                                                    UI Backend就是绘制页面图层的模块。

4.2,RN视图绘制

4.2.1,启动渲染(从组件的角色剖析--android)

简单说就是Native初始化 -> 加载JS,JS端注册组件 ->端上调用JS端run方法,传入入口组件名称 -> JS端启动渲染流程。

4.2.2,组件渲染--View

创建: ReactNative的UI组件通过requireNativeComponent->createReactNativeComponentClass->ReactNativeBaseComponent下mountComponent的调用关系,最终在mountComponent中调用UIManager(Native Module)组件创建View:UIManager.createView(tag, this.viewConfig.uiViewClassName, nativeTopRootTag, updatePayload);,在Native端,UIManager调用对应组件类型的ViewManager(单例,管理类)创建实例。

更新:属性--样式同步,也就是re-render的过程,在这过程中会调用ReactNativeBaseComponent下receiveComponent->UIManager.updateView完成。

参考: https://github.com/facebook/react-native/            http://facebook.github.io/react-native/            http://www.jianshu.com/p/17d6f6c57a5c

相关文章

  • React-Native 样式、布局、绘制

    1,写在前面 在web开发中,以往结构、样式、行为的开发通常是分离的,也就是所谓的“关注点分离(separatio...

  • 京东顶部导航条(html/css)

    思路:1、引入重置样式表2、引入font awesome样式表 3、创建外围容器、内部容器,绘制布局 4、外部容器...

  • 非样式布局

    非布局样式-字体 非布局样式 - 行高 非样式布局 - 背景 非布局样式 - 边框 非布局样式 - 滚动 非布局样...

  • react-native 布局篇

    react-native 布局篇之单位换算(px转dp) react-native 布局篇之flexbox rea...

  • React-Native基础,布局之Flex

    Flex是React-Native中重要的布局手段之一。在组件样式中使用flex可以使其在可利用的空间中动态...

  • 浏览器渲染流程

    渲染流程: 构建 DOM 树、样式计算、布局阶段、分层、绘制、光栅化 和 合成。 构建 DOM 树 这是因为浏览...

  • React-Native 相关样式学习

    React-Native 样式指南 React-Native 的样式基本上是实现了 CSS 的一个子集,并且属性名...

  • nx.draw()

    nx.draw()方法,至少接受一个参数:待绘制的网络G 参数: 运行样式: 运用布局: circular_lay...

  • day07

    1.布局 1.默认布局2.float布局3.层级布局(定位布局) 2.css样式的引入 3.外部样式 外部样式表 ...

  • 03-Flexible Box

    概念 React-Native 中所有的布局均采用 Flex 布局。采用 Flex 布局的元素,称为 Flex 容...

网友评论

    本文标题:React-Native 样式、布局、绘制

    本文链接:https://www.haomeiwen.com/subject/lhqdixtx.html