RN千机变

1.技术体系问题

RN和React共用一套抽象层,相对于前端,RN其实更接近Node的运行环境

ReactNative =React +IOS +Android

看RN文档时,我会发现入门基础那一块介绍的都是React的内容,进阶篇则介绍了很多IOS和Android的API

2.组件设计问题

Android和IOS一些设计组件是不共通的,这意味着,原本在React上只返回一个组件的情况下,RN中你可能需要判断平台分别返回两个版本的组件,为什么要这样? 因为对于许多组件,两个平台的风格差异实在太大,只能分而治之。

3.静态资源问题

RN应用和普通Web应用有一些天生的差别,RN应用是可以植入预定的静态资源的,也就是不需要经过任何一次请求,而都可以本地使用的静态资源,而Web应用试图使用这种资源则需要经过至少一次的网络请求并且缓存,但仍有可能被用户强清缓存等操作付之一炬。

这意味着,做性能优化时也许可以从静态资源入手了,我阅读了以下文章后 探索 react native 首屏渲染最佳实践

学习到了可以通过静态文件占位图优化RN首屏的新思路。当然,很多时候React和RN的优化思路也是共通的,例如

  • 资源预先缓存
  • 长列表延迟加载等等

4.标签生效问题

  • <div>不能用啦,要用<view>
  • <p>标签用不了啦,要用<Text>
  • 没有<img>了,取而代之的是<Image>
  • 背景,可以用ImageBackground这个组件
  • 列表,不能用ul/li啦,用ListView组件吧兄弟
  • 各种Input,不能用input标签啦~ 要用对应的原生控件,比如TextInput、Picker、Switch、Slider

5.事件核心问题

Web开发中,点击事件是核心,而在主攻移动端的RN中,触摸事件的地位则大大增强,而且除此之外,还衍生了长按事件(JS中我记得只有双击事件没有长按事件)

  • onPressOut等等
  • onLongPress 等等

6.CSS3属性受限,动画效果使用方式完全变更

CSS/Animation我用不了了,因为CSS已经没了了,底层是用bridge调原生的UI构建

7.虚拟DOM到虚拟View的演变

在React中,我们使用虚拟DOM模拟现实中的DOM节点

在RN中,这个对象被换成了虚拟View,对应原生平台中的视图,因为RN中已经没有DOM了

8.UI呈现的变化

(以下参考自: http://blog.ilibrary.me/2016/12/25/react-native-internal)

UI的描述和呈现分离开了。

  1. html文本描述了页面应该有哪些功能,css告诉浏览器该长什么样。
  2. 浏览器引擎通过解析html和css,翻译成一些列的预定义UI控件,
  3. 然后UI控件去调用操作系统绘图指令去绘制图像展现给用户。
  4. Javascript可有可无,主要用于html里面一些用户事件响应,DOM操作、异步网络请求和一些简单的计算。

在react native 里面,1和2是不变的,也是用html语言描述页面有哪些功能,然后stylesheet告诉浏览器引擎每个控件应该长什么样。并且和浏览器用的是同一个引擎。
在步骤3里面UI控件不再是浏览器内置的控件,而是react native自己实现的一套UI控件(两套,android一套,ios一套),这个切换是在MessageQueque中进行的,并且还可以发现,他们tag也是不一样的。参考链接:http://blog.ilibrary.me/2016/12/25/react-native-internal

RN大观园

  1. IOS9只支持https,以http加载网络图片资源是无效的
  2. React-native内置babel转换器和ES6的polypill
  3. RN使用的引擎是safari的引擎而我们一般调试的时候用的是Chrome的V8引擎
  4. 遇到频繁修改属性的场景,为了避免影响性能,建议使用setNativeProp直接修改属性,而不是走setState的流程
  5. 测试元素和包裹容器的距离,在普通场景中我们可能会考虑scrolltop,offsetTop等一堆属性,在RN中可以通过一个方法,叫measure和measureLayOut,能分别测以某个元素为参考点的相对位置和绝对位置
  6. RN相对于普通web应用,增加了一个属性叫hsl,可以指定:色度-饱和度-亮度,是不是感觉和rgba很类似的作用呀
  7. 如果访问的一些API,但是RN平台暂时没有做封装,就需要自己用Object-C或者Android实现
  8. 数据库: RN是移动端应用,那不就意味着可以用Android等的数据库或者文件系统了吗? 在RN中这似乎被封装成了AsyncStroage,如果觉得API还不能满足的话,可以用社区里的一个高性能的RN库——realm
  9. 后台任务可以很方便的用了,就像web-worker一样
  10. 编写跨平台代码时候,RN专门提供了Platform对
  11. Plaform.OS: 返回平台名称,比如iOS或者android
  • Plaform.Version: 返回版本
  • Plaform.select: 方法,接收一个对象,可以分别指定ios和android环境下的返回值,酌情返回

12.导航有提供专门的模块:比如react-navigation和react-native-navigation

13.动画要用Animated控件,不能自己写CSS3的动画属性了,比如Animation和transition

当React开发者初次走进React-Native的世界的更多相关文章

  1. 走进React

    走进React React是一个构建用户界面的JavaScript库,是Facebook公司在2013年5月在github上开源的.其特点如下: 高效--React通过对DOM的模拟,最大程度地减少和 ...

  2. 用 React 编写移动应用 React Native

    转载:用 React 编写移动应用 React Native ReactNative 可以基于目前大热的开源JavaScript库React.js来开发iOS和Android原生App.而且React ...

  3. 京东云开发者|关于“React 和 Vue 该用哪个”我真的栓Q

    一.前言:我全都要 面对当今前端界两座大山一样的主流框架,React和Vue,相信很多小伙伴都或多或少都产生过这样疑问,而这样的问题也往往很让人头疼和犹豫不决: 业务场景中是不是团队用什么我就用什么? ...

  4. 1. React介绍 React开发环境搭建 React第一个程序

    什么是 React         React 是 Facebook 发布的 JavaScript 库,以其高性能和独特的设计理念受到了广泛关注. React的开发背景         Faceboo ...

  5. 【react学习】关于react框架使用的一些细节要点的思考

    ( _(:3 」∠)_给园友们提个建议,无论是API文档还是书籍,一定要多看几遍!特别是隔一段时间后,会有意想不到的收获的)   这篇文章主要是写关于学习react中的一些自己的思考:   1.set ...

  6. [React] 02 - Intro: why react and its design pattern

    为啥使用React,给我个理由 过去 需要手动更新DOM.费力地记录每一个状态:既不具备扩展性,又很难加入新的功能,就算可以,也是有着冒着很大的风险. 不过,使用这种开发方式很难打造出极佳的用户体验. ...

  7. 转载 React.createClass 对决 extends React.Component

    先给出结论,这其实是殊途同归的两种方式.过去我们一般都会使用 React.createClass 方法来创建组件,但基于 ES6 的小小语法糖,我们还可以通过 extends React.Compon ...

  8. 【React 资料备份】React Hook

    Hooks是React16.8一个新增项,是我们可以不用创建class组件就能使用状态和其他React特性 准备工作 升级react.react-dom npm i react react-dom - ...

  9. [转] React 最佳实践——那些 React 没告诉你但很重要的事

    前言:对很多 react 新手来说,网上能找到的资源大都是些简单的 tutorial ,它们能教会你如何使用 react ,但并不会告诉你怎么在实际项目中优雅的组织和编写 react 代码.用谷歌搜中 ...

随机推荐

  1. Selenium+java - 日期控件的处理

    前言 一般的日期控件都是input标签下弹出来的,设置日期使用selenium中的sendKeys 方法就可以解决. 但是我们也会碰到下面的时间日期控件(这个时候这个文本框是不允许我们输入时间的)如图 ...

  2. ibatis 核心原理解析

    最近查找一个生产问题的原因,需要深入研究 ibatis 框架的源码.虽然最后证明问题的原因与 ibatis 无关,但是这个过程加深了对 ibatis 框架原理的理解. 这篇文章主要就来讲讲 ibati ...

  3. Go中的字符串使用----strings和strconv

    Go中的字符串操作 字符串是工作中最常用的,值得我们专门的练习一下.在Go中使用strings包来操作字符串,这也是内置的包哈,不像Java中要么手写,要么引入common-lang 或者 别的第三方 ...

  4. Unity进阶之:Shader渲染

    版权声明: 本文原创发布于博客园"优梦创客"的博客空间(网址:http://www.cnblogs.com/raymondking123/)以及微信公众号"优梦创客&qu ...

  5. 【记忆化搜索】掷骰子 hpuoj

    B. 掷骰子 单点时限: 2.0 sec 内存限制: 512 MB 骰子,中国传统民间娱乐用来投掷的博具,早在战国时期就已经被发明. 现在给你 n 个骰子,求 n 个骰子掷出点数之和为 a 的概率是多 ...

  6. 循环 与 分支语句 和 字符函数库cctype 文件简单处理

    循环 for循环 while循环 do  while循环 通常,入口条件循环比出口条件循环好,因为循环开始前对条件进行检查 c++11基于范围的for循环    对数组(或容器类,如:vector和a ...

  7. Nginx总结(一)Linux如何安装Nginx

    以前写过一些Nginx的文章,但都是用到什么说什么,没有一个完整系统的总结.趁最近有时间,打算将Nginx相关的内容重新整理一下.nginx系列文章地址如下:https://www.cnblogs.c ...

  8. Python day01 课堂笔记

    今天是第一天学习Python课程,主要从计算机基础,Python的历史,环境 ,变量,常量,注释,用户交互,基础数据类型 ,简单的if条件语句和while循环语句这几个来学习,重点的掌握内容是pyth ...

  9. 【selenium】- 常见浏览器的启动

    本文由小编根据慕课网视频亲自整理,转载请注明出处和作者. 1. Firefox启动 webdriver自带了firefox浏览器的驱动,所以不需要设置它的驱动. 如果firefox没有安装在默认路径, ...

  10. Eclipse批量注释、批量缩进、批量取消缩进技巧

    1.批量注释:选中若干行,按"Ctrl"+"/" 2.批量缩进:选中若干行,按TAB 3.批量取消缩进:选中若干行,按SHIFT+TAB