开始了解React Native
React是什么?
React是一个比较热门的前端框架,可以描述为一个用来构建用户界面的javascript库,(GitHub地址)。它起源于Facebook的内部项目,因为 FB 对市场上所有 JavaScript MVC 框架,都不满意,就决定自己写一套,用来架设 Instagram 的网站。做出来以后,发现这套东西很好用,就在2013年5月开源了。
由于 React 的设计思想极其独特,属于革命性创新,性能出众,代码逻辑却非常简单。所以,越来越多的人开始关注和使用,认为它可能是将来 Web 开发的主流工具。
和Backbone、Angular 等MV*框架不一样,它只处理View逻辑 。所以如果你喜欢它,你可以很容易的将它接入到现有工程中,然后用React重写HTML部分即可,不用修改逻辑。
近几年web领域的技术革新非常迅速,React 也是一项新技术,其实React出来也多年了,其实并不算什么新技术了,只是在国内还没有普及开。国内在热更新方面更热衷于纯Native的插件化技术。可以说,Android的未来必将是React-Native和插件化的天下……
React Native
React Native是由React衍生出来的项目(GitHub地址),基于React来写的支持编写原生App的框架,目标是希望用写Web App的方式去写Native App。React Native看起来很像React,只不过其基础组件是原生组件而非web组件。
React Native能给移动开发带来什么?
像比较于Hybird app,Native app 以及Webapp,React Native有以下优势:
- 极速的渲染性能:不用Webview,彻底摆脱了Webview让人不爽的交互和性能问题。
- 组件互相独立,关系隔离,可复用,有较强的扩展性:Native端提供的是基本控件,JS可以自由组合使用。
- 跨平台: Write once,run anywhere. React 能够用一套代码同时运行在浏览器和 node 里,而且能够以原生 App 的姿势运行在 iOS 和 Android 系统中,即拥有了 web 迭代迅速的特性,又拥有原生 App 的体验。
- JS与Native原生优势互补:JS可以直接使用原生一些控件或者是JS里面比较难以实现的UI效果。
- 可以通过更新远端JS,直接更新App,不过现在热修复也基本已成为Native app的标配了。
精通了React开发,感觉自己是不是有『全栈工程师』的特点了呢?
其他类似的一些开源框架
- Weex:基于vue.js开发,使用V8作为JS引擎。
一些学习资料
React Native的相关文档https://facebook.github.io/react/ https://facebook.github.io/react-native/
React 中文网
React Native中文网
ECMAScript 6入门
React/React Native 的ES5 ES6写法对照表
分析reactnative优劣
ReactNativeAndroid源码分析-Js如何调用Native的代码
ReactNative For Android 项目实战总结 QQ空间
React Native For Android 架构初探 QQ空间
React native for Android 初步实践(淘宝)
ReactNative开发指导
随后继续补充