react-native 简介及环境
概要
- react native
 - 环境搭建
 - hello react native
 - react native 发布
 
react native
优势
- 不用再学习 OC,Swift,Java,Kotlin 等
 - 复用 react 开发的种种好处
 - 开发体验好(即时编译)
 - 编译出来的是原生应用,不是 html5 app,也不是 hybrid app
 - 可以方便的和原生代码写的控件集成
 
劣势
- 还在发展中,更新频繁,既有可能存在暗坑
 - 性能调优的方式没有真正的原生开发多
 
环境搭建
npm install -g react-native-cli
npm install -g create-react-native-app
npm install -g watchman
hello react native
创建工程
create-react-native-app sample
启动工程
cd sample
yarn start
通过 expo 来查看运行结果
发布
android 发布
下载 android 环境
- 下载 android sdk(如果不用 android studio 开发,可以只下载 sdk 即可)
 - 下载地址:https://developer.android.com/studio/index.html
 
配置 android 环境
解压 sdk 到 opt/android
配置 .zshenv / .bashenv
export ANDROID_HOME=/opt/android
export PATH=$PATH:$ANDROID_HOME/tools
export PATH=$PATH:$ANDROID_HOME/platform-tools
安装 platform-tools
cd $ANDROID_HOME
./tools/bin/sdkmanager platform-tools
安装 build-tools
cd $ANDROID_HOME
./tools/bin/sdkmanager "build-tools;23.0.1"
创建签名
yarn eject
cd android
keytool -genkey -v -keystore my-app-key.keystore -alias my-app-alias -keyalg RSA -keysize 2048 -validity 10000
创建签名时,密码用 123456
配置签名
vim ./android/gradle.properties
MYAPP_RELEASE_STORE_FILE=my-app-key.keystore
MYAPP_RELEASE_KEY_ALIAS=my-app-alias
MYAPP_RELEASE_STORE_PASSWORD=123456
MYAPP_RELEASE_KEY_PASSWORD=123456
把生成的文件 my-app-key.keystore 放入 android/app 文件夹下
vim ./android/app/build.gradle
android {
defaultConfig {... ...}
signingConfigs {
release {
if (project.hasProperty('MYAPP_RELEASE_STORE_FILE')) {
storeFile file(MYAPP_RELEASE_STORE_FILE)
storePassword MYAPP_RELEASE_STORE_PASSWORD
keyAlias MYAPP_RELEASE_KEY_ALIAS
keyPassword MYAPP_RELEASE_KEY_PASSWORD
}
}
}
buildTypes {
release {
... ...
signingConfig signingConfigs.release
}
}
}
发布
cd android
./gradlew assembleRelease
生成的 apk 在 app/build/outputs/apk 下
附录
启动一直卡在 Starting packager…
修改如下内核参数后再启动:
sudo sysctl -w fs.inotify.max_user_watches=1000000
永久修改此参数,可以把这个配置加入到: /etc/sysctl.conf 中
./gradlew assembleRelease 时无法运行 aapt
java.io.IOException: Cannot run program "/opt/android/build-tools/23.0.1/aapt": error=2, No such file or directory
安装 确实的 package
sudo  apt-get install lib32stdc++6 lib32z1
Couldn't find preset "babel-preset-react-native-stage-0/decorator-support"
安装相应的 package
cd ..
yarn add babel-preset-react-native-stage-0
cd android
./gradlew assembleRelease												
											react-native 简介及环境的更多相关文章
- react-native —— 在Windows下搭建React Native Android开发环境
		
在Windows下搭建React Native Android开发环境 前段时间在开发者头条收藏了 @天地之灵_邓鋆 分享的<在Windows下搭建React Native Android开发环 ...
 - react native 学习一(环境搭配和常见错误的解决)
		
react native 学习一(环境搭配) 首页,按照http://reactnative.cn/docs/0.30/getting-started.html#content上的介绍,下载安装pyt ...
 - React Native 简介:用 JavaScript 搭建 iOS 应用(2)
		
[编者按]本篇文章的作者是 Joyce Echessa--渥合数位服务创办人,毕业于台湾大学,近年来专注于协助客户进行 App 软体以及网站开发.本篇文章中,作者介绍通过 React Native 框 ...
 - React Native 简介:用 JavaScript 搭建 iOS 应用 (1)
		
[编者按]本篇文章的作者是 Joyce Echessa--渥合数位服务创办人,毕业于台湾大学,近年来专注于协助客户进行 App 软体以及网站开发.本篇文章中,作者介绍通过 React Native 框 ...
 - react-native —— 在Mac上配置React Native Android开发环境排坑总结
		
配置React Native Android开发环境总结 1.卸载Android Studio,在终端(terminal)执行以下命令: rm -Rf /Applications/Android\ S ...
 - React Native搭建开发环境   之  --走过的坑
		
React Native是使用JavaScript和React编写原生移动应用 我的开发平台是基于windows系统,所以只支持android,要是想开发ios系统,那就只能考虑使用沙盒环境 接下来就 ...
 - 《React Native 精解与实战》书籍连载「React 与 React Native 简介」
		
此文是我的出版书籍<React Native 精解与实战>连载分享,此书由机械工业出版社出版,书中详解了 React Native 框架底层原理.React Native 组件布局.组件与 ...
 - 【React Native开发】React Native For Android环境配置以及第一个实例(1)
		
年9月15日也公布了ReactNative for Android,尽管Android版本号的项目公布比較迟,可是也没有阻挡了广大开发人员的热情.能够这样讲在2015年移动平台市场上有两个方向技术研究 ...
 - 一、React Native 搭建开发环境(1)(Mac OS - IOS项目篇)
		
React Native是Facebook推出的一个开发IOS和安卓APP的技术.至于更多的详情,这里不再描述,大家可以自行百度它的定义. 原因:由于我想在一台电脑上同时开发IOS和Android两个 ...
 - React Native IOS ---基础环境搭建(前端架构师)
		
React Native -IOS 开发环境搭建 web架构(基础) 安装依赖 * 必须安装的依赖有:Node.Watchman 和 React Native 命令行工具以及 Xcode. npm 镜 ...
 
随机推荐
- MySQL备份mydumper的原理【转】
			
本文来自:http://baiyangtx.net/2016/09/04/mydumper-principle/ 相对于MySQL官方提供的逻辑备份工具 mysqldump , mydumper最大的 ...
 - Java之判断大整数是否为平方数
			
在本篇博客中,我们将讨论如何使用有效的算法来判断一个大整数是否为平方数. 给定正整数\(n\),如果存在一个整数\(m\),满足\(m^{2}=n\),那么则称\(n\)为平方数.因此,判断一 ...
 - html中的Session
			
采用setItem()方法存储 sessionStorage.setItem('testKey','这是一个测试的value值'); // 存入一个值sessionStorage.getItem('t ...
 - 如何快速将一个list<a>集合中的部分字段值组合成新的的list<b>部分*
			
有的时候,我们只需要从老数据中拿一部分数据作为新的绑定数据,比如说绑定下拉框的时候需要构造我们需要的数据格式可以采用以下的方法 public class SelectDataViewModel { p ...
 - html 三列布局(两列自适应,一列固定宽度)
			
不做过多解释:主要是记录一个完整的布局样式,实现页面大致三列其中左右两列是自适应宽度,中间固定宽度效果. 不多少代码奉上: CSS样式代码: /******************** *公共标签样式 ...
 - 推送GitHub报错 fatal: Out of memory, malloc failed 解决办法
			
现象: 推送GitHub时,出现如下报错 fatal: Out of memory, malloc failed (tried to allocate XXXXXX bytes)error: fail ...
 - SSM 设置静态资源处理
			
使用weblogic的虚拟路径virtual-directory-mapping 在页面上展示文件服务器上的图片 <weblogic-web-app> ......省略其他部分 <c ...
 - HashMap深度解析
			
最基本的结构就是两种,一种是数组,一种是模拟指针(引用),所有的数据结构都可以用这两个基本结构构造,HashMap也一样.当程序试图将多个 key-value 放入 HashMap 中时,以如下代码片 ...
 - 【代码笔记】Web-JavaScript-javascript while循环
			
一,效果图. 二,代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...
 - 使用JDBC连接MySQL数据库的一个基本案例
			
JDBC的概念(摘自百度百科) JDBC(Java DataBase Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一 ...