- React 起源于 Facebook 的内部项目,用来架构 Instrgram 的网站(一款图片分享的社交软件),并与 2013 年 5 月份开源,距今已经有 5 年历史。
- React 是一个用于构建用户界面的 JavaScript 库。主要用于构建 UI,很多人认为 React 是 MVC 中的 V(视图)。
- React 拥有较高的性能,代码逻辑非常简单,越来越多的人已开始关注和使用它。
- React Native 是基于 React 衍生出来一项技术,用我们熟悉的 React 来开发 Mobile App
- 都使用 React Virtual Dom 做为 DSL(领域专用语言)
- 都用 JSX 语法
- React 以浏览器 DOM 作为载体显示
- React Native 以 Native 控件作为载体显示
- React 用 Webpack 之类的打包工具
- React Native 使用自带的打包工具
react packager
(现在改名叫 metro),最终生成的离线的 jsbundle 文件以 assets(资源) 的形式打包到 Android 的 apk 或 iOS 的 ipa 里 - React 可以使用
Plain CSS
,LESS
,SASS
和styled-components
等 - React Native 用
CSS in JavaScript
(推荐)或styled-components
对比 | HTML5 | Native | React Native |
---|---|---|---|
人才成本 | 低,一个人当三个人用 | 高,iOS 和 Android 两个团队 | 低,一个人当三个人用 |
更新能力 | 快,修改完直接部署 | 慢,需要提交审核 | 中,修改完直接部署(使用热更新) |
学习成本 | 设备要求低,学习入门快 | 需买设备与证书,学习入门慢 | 需买设备,学习入门快 |
版本控制 | 及时,用户每次看到即最新 | 不及时,需等用户升级 | 及时,用户每次看到即最新(使用热更新) |
跨端复用 | 高,全部复用 | 低,三端各自写自己那部分 | 中,Android 和 iOS 可以复用 |
性能 | 低,大概 70 分 | 高,大概 95 分 | 中高,大概 85 ~ 90 分 |
维护成本 | 低,一个人当三个人用 | 高,Android 和 iOS 团队各自写自己团队的代码 | 中低,一个维护 Android 和 iOS 两端代码 |
简单来说
- JavaScript -> JavaScript Bridge -> Native Bridge -> Native
- Native -> Native Bridge -> JavaScript Bridge -> JavaScript
说人话就是:在 React Native 的应用中,存在着两个不同的技术王国:JS 王国和 Native 王国。应用在启动时会先进行双向注册,搭好桥,让两个王国知道彼此的存在,以及定义好彼此合作的方式:
更详情的解释
- iOS 与 JavaScript 通讯(图片来自于知乎,侵删)
- JavaScript 与 iOS 通讯(图片来自于伯乐在线,侵删)
React Native 最终还是以 Native 的形式显示在两端的设备上,所以每个 React Native 控件都映射着一个 Native 控件,例如:
- React Native 控件中的 Text 对应着
- iOS 的 UILable
- Android 的 TextView
- Node (含 NPM)环境
- NodeJS 使用 8.0+, NPM 使用 5.0+,推荐安装 LTS 版本
- 推荐为 NPM 配置国内镜像,如:淘宝源
- Git
- Xcode 8.0+(需使用 iPhone 模拟器)
- Android Studio 选装
- npm install -g react-native-cli
- react-native init
projectName
-
下载 third-party 文件
第一次编译 iOS 端应用时,需要手动配置 https://reactnative.cn/post/4301 。
-
iOS 不能访问网络
苹果要求 iOS9 以后 App 内访问的网络必须使用 HTTPS 协议。 如果你的 API 不支持 HTTPS,需要手动配置 https://segmentfault.com/a/1190000002933776 。
- CSS in JavaScript
React Native 中使用 JS 来编写样式,没有完整实现 Web 中的 CSS。因为全部实现了,等价于实现了浏览器内核。React Native 的卖点就是性能,即比 WebView 快,几乎跟原生一样快。
- Babel
默认使用 ES6 方式编写代码,需要 Babel 来编译。
- 过度「优化」的国产 Android 手机
- 小米 4C
- 魅族
- 新流海的 iPhone X
- React Native
- react
- redux
- reselect
- immutable
- code push
- react navigation
- babel
- eslint
- jest
- Weex
- Vue
- Vuex
- 等
- Flutter 是 Google 开发的跨平台技术,使用 Dart 语言来开发。由于我没有使用过 Flutter 开发过项目,只能引用 ZacJi 的 React Native VS Flutter 评测。
- Taro 跟 「React Native」和 「Flutter」不是同一种技术(后两者属于 APP 跨平台开发),而 Taro 是一种包装或改造技术,他以微信小程序框架为基础,再使用「类 React」的语法(nerv),生成能运行在微信小程序、H5、React Native 等的应用。
- 前端同学能写出高性能的功能(需求),PM 再也不拿卡说事(原生 APP 里集成 React Native 页面)。
- 前端同学能独立做一个「简单」的两端 APP(小公司非常适合,私单也是可以的^_^)。
- 前端同学的价值更高了,地位提升,再也不是一个切图仔。
- React Native APP 可以编译成:Android, Android TV,iPhone, iPad, Apple TV 等 APP。因为底层 Facebook 帮我们搞定了,我们要做的就是把页面写成 flex 布局。
- 可以用 React Native 来代替 APP 里的 HTML5 页面。
Facebook 正在重构 React Native,将重写大量底层,通过引入更先进的架构,来提高 JavaScript 和混合开发中原生 API 的互通性
- 英语版 http://facebook.github.io/react-native/blog/2018/06/14/state-of-react-native-2018
- 中文版 https://www.oschina.net/news/97129/state-of-react-native-2018
- 国外
- Airbnb
- Walmart
- Skype
- 更多 https://facebook.github.io/react-native/showcase.html
- 国内
- QQ(Android)、QQ 空间、QQ 音乐、QQ 课堂
- 手机百度
- 京东、京东金融
- 58 同城、转转
- 携程、艺龙、去哪儿
- 更多 https://reactnative.cn/cases.html