各种命令

个人习惯在项目根目录下把一些常见命令写成bat文件,以后每次要执行什么只需要双击即可:

编译、生成、运行并启动packager(debug模式):

  1. react-native run-android

所谓packager其实就是一个文件同步服务,默认监听8081端口,启动它之后,运行debug模式的ReactNative应用可以随时reload我们的JS。有时候使用上面的命令之后packager服务没有自动启动,此时需要我们手动启动。

我们还可以直接在AndroidStudio中运行项目,然后手动启动packager服务即可:

  1. react-native start

当然,如果你的apk已经安装到了设备上,那么直接启动packager就可以开始开发了。

生成release包的命令见后面。

bundle文件介绍

bundle文件是一个JS文件的大集合,对于Android平台,就叫index.android.bundle,一般有几百kb,里面包括你自己写的JS和RN自带的一些模块代码,是一个文本文件,可以直接用记事本打开。

默认debug模式下,生成的apk里面的index.android.bundle只是ReactNative默认的一个HelloWorld页面,如果packager正在运行,那么这个apk会连接这个packager提供的服务,将js和其它资源打包成index.android.bundle并加载。所以,如果你的packager服务没有开启,可能看到的只是一个默认的HelloWorld页面。

开启实时reload和remote debug

debug 模式下的RN应用自带了一个辅助菜单(双击字母R,或者Ctrl+M,或者直接按模拟器上的菜单键都可以打开它):

选择reload,可以手动重新加载js,如果新添加了图片则需要重新运行apk才可以生效。

选择Enable Live Reload可以开启实时文件同步,修改了JS之后可以立即自动生效,无需手动reload;

选择Debug JS Remotely可以开启远程调试,会自动用Chrome打开http://localhost:8081/debugger-ui,然后需要我们手动按下F12打开控制台,在Console面板记得按下图选择一下:

在这里执行代码就会直接作用到RN上,比如alert之后,会在界面弹出提示。

对于Sources面板,我们的JS和图片等资源在这里全部可以看得到:

要支持断点调试的话好像还要借助一个插件,这个没试过。

发行正式包

很多东西需要打正式的release包才能测试,比如热更新,所以本小节先介绍如何配置打包。

生成签名文件:

  1. cd android/app
  2. keytool -genkey -v -keystore my-release-key.keystore -alias my-key-alias -keyalg RSA -keysize 2048 -validity 36500

按照提示一直下一步,其中,my-key-alias是别名,可随意指定,记住你设置的密码,密钥口令和密钥库口令一般都设置相同。执行上述命令后会在android/app下生成my-release-key.keystore文件。

打开android\app\build.gradle文件,在defaultConfig后面追加signingConfigs相关配置,在buildTypes.release中增加signingConfig一行:

  1. defaultConfig {...}
  2. signingConfigs {
  3. release {
  4. storeFile file("my-release-key.keystore")
  5. keyAlias "my-key-alias"
  6. storePassword "123456"
  7. keyPassword "123456"
  8. }
  9. }
  10. splits {...}
  11. buildTypes {
  12. release {
  13. ...
  14. signingConfig signingConfigs.release
  15. }
  16. }

不清楚的看截图:

在项目根目录上新建一个生成release包.bat,以后双击即可生成正式包了:

  1. cd android && gradlew assembleRelease

生成并安装release包.bat:

  1. cd android && gradlew installRelease

ReactNative学习笔记(三)打包、调试、运行等相关介绍的更多相关文章

  1. openresty 学习笔记三:连接redis和进行相关操作

    openresty 学习笔记三:连接redis和进行相关操作 openresty 因其非阻塞的调用,令服务器拥有高性能高并发,当涉及到数据库操作时,更应该选择有高速读写速度的redis进行数据处理.避 ...

  2. Apache Ignite 学习笔记(三): Ignite Server和Client节点介绍

    在前两篇文章中,我们把Ignite集群当做一个黑盒子,用二进制包自带的脚本启动Ignite节点后,我们用不同的客户端连接上Ignite进行操作,展示了Ignite作为一个分布式内存缓存,内存数据库的基 ...

  3. react-native学习笔记--史上最详细Windows版本搭建安装React Native环境配置

    参考:http://www.lcode.org/react-native/ React native中文网:http://reactnative.cn/docs/0.23/android-setup. ...

  4. VSTO学习笔记(三) 开发Office 2010 64位COM加载项

    原文:VSTO学习笔记(三) 开发Office 2010 64位COM加载项 一.加载项简介 Office提供了多种用于扩展Office应用程序功能的模式,常见的有: 1.Office 自动化程序(A ...

  5. 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记

    回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...

  6. ES6学习笔记<三> 生成器函数与yield

    为什么要把这个内容拿出来单独做一篇学习笔记? 生成器函数比较重要,相对不是很容易理解,单独做一篇笔记详细聊一聊生成器函数. 标题为什么是生成器函数与yield? 生成器函数类似其他服务器端语音中的接口 ...

  7. angular学习笔记(三十一)-$location(2)

    之前已经介绍了$location服务的基本用法:angular学习笔记(三十一)-$location(1). 这篇是上一篇的进阶,介绍$location的配置,兼容各版本浏览器,等. *注意,这里介绍 ...

  8. python3.4学习笔记(三) idle 清屏扩展插件

    python3.4学习笔记(三) idle 清屏扩展插件python idle 清屏问题的解决,使用python idle都会遇到一个常见而又懊恼的问题——要怎么清屏?在stackoverflow看到 ...

  9. amazeui学习笔记三(你来我往1)--常见问题FAQs

    amazeui学习笔记三(你来我往1)--常见问题FAQs 一.总结 1.DOM事件失败:记得加上初始化代码,例如 图片轮播 $('#my-slider').flexslider(); 2.jquer ...

  10. 物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus

    物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus 物联网 (IoT) 不只是新技术,还是与旧技术的集成,其关键在于通信.可用的通信方法各不相同,但是,各种不同的协议在将海量“事物”连接 ...

随机推荐

  1. 代码: jquery 插件开发(自用插件)

    http://www.imooc.com/learn/99 阿当大话西游之WEB组件 2016-4-19 jquery插件开发: 2016-3-1 http://www.cnblogs.com/Way ...

  2. leetcode207

    拓扑排序问题. class Solution { public: bool canFinish(int numCourses, vector<pair<int, int>>&a ...

  3. XGBoost参数调优小结

    https://mp.weixin.qq.com/s?__biz=MzU0MDQ1NjAzNg==&mid=2247485630&idx=1&sn=9edf2bfd771cf4 ...

  4. kalman filter卡尔曼滤波器- 数学推导和原理理解-----网上讲的比较好的kalman filter和整理、将预测值和观测值融和

    = 参考/转自: 1 ---https://blog.csdn.net/u010720661/article/details/63253509 2----http://www.bzarg.com/p/ ...

  5. docker-compose学习

    该实践是在已经安装了docker的基础上,如果还未安装docker,请先安装docker : https://www.cnblogs.com/theRhyme/p/9813019.html docke ...

  6. Python开发【第五篇】:模块

    递归的案例:阶乘 1*2*3*4*5*6*7- def func(num):     if num == 1:         return 1     return num * func(num - ...

  7. Python面向对象中的classmethod类方法和__getattr__方法介绍

    一.classmethod介绍 介绍:@classmethod修饰符我们从名称就可以知道,这是一个类方法,那么和普通的类中的方法有什么不同的 a.类方法,是由类本身调用的,无需实例化类,直接用类本身调 ...

  8. python—切片

    切片就是list取值的一种方式 l = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] print(l[1:5]) #取值方式顾头不顾尾 print(l[:5]) #冒号 前面 没写代 ...

  9. [leetcode]58. Length of Last Word最后一个词的长度

    Given a string s consists of upper/lower-case alphabets and empty space characters ' ', return the l ...

  10. leetcode3:无重复字符的最长子串

    给定一个字符串,找出不含有重复字符的最长子串的长度. 示例: 给定 "abcabcbb" ,没有重复字符的最长子串是 "abc" ,那么长度就是3. 给定 &q ...