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技术完全可以满足要求,而又不触碰苹果的底线。
网友评论