微信号:infoqchina

介绍:有内容的技术社区媒体

React Native:Facebook出品,可用JavaScript开发移动原生应用

2015-02-04 11:49 李小兵


近日,在React.js 2015大会上,Facebook公布了即将开源的React Native,它基于开源框架React.js,并可用来开发iOS和Android原生应用。目前,Facebook已经将React Native投入到了实际生产环境中,并开发出了基于iOS平台的聊天工具Groups。

从ProgVille发布的一篇题为React Native—使用React.js开发原生应用的文章中得知以下React Native的相关信息:


1,React Native已实现了对iOS和Android两大平台的支持。


2,使用React Native开发原生应用的原理是:在JavaScript中用React.js抽象操作系统的原生UI组件,继而代替DOM元素来渲染,比如使用<View>取代<div>,使用<Image>替代<img>等。在后台,React Native运行在主线程之外,而在另一个专门的后台线程里运行JavaScript引擎,两个线程之间通过异步消息协议来通信(有个专门的插件)。


3,在UI方面,React Native提供了一个跨平台、类似Flexbox的布局系统,并且还支持CSS子集。


4,可以用JSX、JavaScript、CoffeeScriptTypeScript来开发。


React/React Native团队成员JordanHack News上分享了React Native的一些基于个人观点的信息,他说到React Native为提高开发效率提供了大量的益处,但是在性能方面,React Native还存在一些问题。同时还指出React Native同其他原生开发应用方式的不同之处,如React Native完全不用DOM、React Native既保证对应用程序性能的要求,同时兼顾Web开发优点;能够使用JavaScript来写高质量的应用等。


Reddit上也有了相关评论信息用户lunchmeat317认为学习React.js的时机到了。用户BishopAndWarlord表示对React Native很好奇并期待获得更多相关信息。


用户jrm2k6评论到:

自己已了解和喜欢他们的理念:一次学习,即可以做自己想着的任何事情。但是现在需要展示一些代码实例了,也许这是一个愚蠢的问题,但是它和Ionic有什么不同,同使用AngularJS开发iOS/Android应用有什么不同?

 

用户arx707接着回答到:

React Native使用React.js作为原生组件的抽象层,而AngularJS和Ionic使用WebViews模拟本地组件,React Native的性能应该和Appcelerator跨平台工具Titanium一样。


React Native基于React.js实现,而React.js是Facebook推出并开源的一个用来构建用户界面的JavaScript库,其已经应用于构建Instagram网站及Facebook部分网站。React.js 同AngularJS、MeteorJS和Polymer类似,它们都属于Model-Driven Views结构的框架,但是React.js又与他们有不同之处,即React.js使用JavaScript而非HTML来构建用户界面。更多关于React.js和React Native的详



 
InfoQ 更多文章 Facebook如何实现PB级别数据库自动化备份 学术派Google软件工程师Matt Welsh谈移动开发趋势 Spotify为什么要使用一些“无聊”的技术? 妹纸们放假了,汉纸们做啥? 大多数重构可以避免
猜您喜欢 稳定性测试|探索优化App UI遍历方法-SmartMonkey 微分享预告 | 携程应用路由的解决方案与实践 IBM Spark大赛启动 10万美元悬赏最佳Spark应用 再议携程Android动态加载框架DynamicAPK React Native 开发之 IDE 选型和配置