ReactNative简介

ReactNative简介



ReactNative是Facebook于2015年4月开源的跨平台移动应用开发框架,是Facebook早先开源的UI框架React在原生移动应用平台的衍生产物,目前支持iOS和Android 俩大平台。

ReactNative可以基于目前大热的开源JavaScript库ReactJS来开发iOS和Android移动应用。

优点:

一套代码可以满足iOS和Android

由于基于Web技术,ReactNative开发起来可以像浏览器那样随改即所见。

原理:

ReactNative的原理是在JavaScript中使用React抽象操作系统的原生UI组件。

比如:代替DOM元素来渲染洁面,比如用View组件取代div,用Image组件取代img等。

线程:

ReactNative主要有2个线程:

主线程和JavaScript引擎线程,俩个线程之间通过批量化的async消息协议来通信。

布局:

在UI方面,ReactNatice提供跨平台的蕾丝Flexbox的布局系统,还支持CSS子集。可以用JSX或者普通JavaScript语言。

Flexbox是什么?

根据规范中的描述可知道,Flexbox模块提供了一个有效的布局方式,即使不知道视窗大小或者未知元素情况之下都可以智能的,灵活的调整和分配元素和空间两者之关的关系。简单的理解,就是可以自动调整,计算元素在容器空间中的大小。

可以理解成一个布局模块

特点:

ReactNatice相比原声开发主要有以下特点:

1.App占用体积小

2.跨平台

3.相对成熟的技术

随着安卓/iOS的ReactNative陆续开源,原声提供的组件和API相对丰富,且实现技术基本一致,对于熟悉前端和原声APP开发的人员来说比较容易上手,而ReactNative 通过 JavaScriptCore将JS转换为原生APP组件进行渲染,体验可媲美原生APP。

什么事JavaScriptCore?

首先要区分JavaScriptCore 和 JavaScriptCore 框架

JavaScriptCore框架 是一个苹果在iOS7引入的框架,该框架让 Objective-C 和 JavaScript 代码直接的交互变得更加的简单方便。

而JavaScriptCore是苹果Safari浏览器的JavaScript引擎,或许你听过Google的V8引擎,在WWDC上苹果演示了最新的Safari,据说JavaScript处理速度已经大大超越了Google的Chrome,这就意味着JavaScriptCore在性能上也不输V8了。

JavaScriptCore框架其实就是基于webkit中以C/C++实现的JavaScriptCore的一个包装,在旧版本iOS开发中,很多开发者也会自行将webkit的库引入项目编译使用。现在iOS7把它当成了标准库。

JavaScriptCore框架在OS X平台上很早就存在的,不过接口都是纯C语言的,而在之前的iOS平台(iOS7之前),苹果没有开放该框架,所以不少需要在iOS app中处理JavaScript的都得自己从开源的WebKit中编译出JavaScriptCore.a,接口也是纯C语言的。可能是苹果发现越来越多的程序使用了自编译的JavaScriptCore,干脆做个顺水人情将JavaScriptCore框架开放了,同时还提供了Objective-C的封装接口。

4.支持动态更新

在原生APP开发中,Android平台可以通过插件化实现热更新,在iOS平台上,热更新策略是严令禁止的(如JSPatch/wax/roollout等技术),而采用ReactNative技术完全可以满足要求,而又不触碰苹果的底线。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,956评论 25 709
  • 当自己慢慢一个人开始自己照顾自己, 就开始自己开始煮饭,自己做菜,打扫卫生,就开始的时候就很想找个女朋友,觉得这些...
    伊人已有佳人阅读 1,625评论 0 0
  • 后院已经完工!跟以前天壤之别。 每天走进家园,心情随之雀跃。有了外部环境的渲染,我们又怎能辜负这片美景。每天昕爸多...
    淡淡百合阅读 3,875评论 7 2

友情链接更多精彩内容