ReactNative学习笔记(三)打包、调试、运行等相关介绍
各种命令
个人习惯在项目根目录下把一些常见命令写成bat文件,以后每次要执行什么只需要双击即可:
编译、生成、运行并启动packager
(debug模式):
react-native run-android
所谓
packager
其实就是一个文件同步服务,默认监听8081端口,启动它之后,运行debug模式的ReactNative应用可以随时reload我们的JS。有时候使用上面的命令之后packager服务没有自动启动,此时需要我们手动启动。
我们还可以直接在AndroidStudio中运行项目,然后手动启动packager服务即可:
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包才能测试,比如热更新,所以本小节先介绍如何配置打包。
生成签名文件:
cd android/app
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
一行:
defaultConfig {...}
signingConfigs {
release {
storeFile file("my-release-key.keystore")
keyAlias "my-key-alias"
storePassword "123456"
keyPassword "123456"
}
}
splits {...}
buildTypes {
release {
...
signingConfig signingConfigs.release
}
}
不清楚的看截图:
在项目根目录上新建一个生成release包.bat
,以后双击即可生成正式包了:
cd android && gradlew assembleRelease
生成并安装release包.bat:
cd android && gradlew installRelease
ReactNative学习笔记(三)打包、调试、运行等相关介绍的更多相关文章
- openresty 学习笔记三:连接redis和进行相关操作
openresty 学习笔记三:连接redis和进行相关操作 openresty 因其非阻塞的调用,令服务器拥有高性能高并发,当涉及到数据库操作时,更应该选择有高速读写速度的redis进行数据处理.避 ...
- Apache Ignite 学习笔记(三): Ignite Server和Client节点介绍
在前两篇文章中,我们把Ignite集群当做一个黑盒子,用二进制包自带的脚本启动Ignite节点后,我们用不同的客户端连接上Ignite进行操作,展示了Ignite作为一个分布式内存缓存,内存数据库的基 ...
- react-native学习笔记--史上最详细Windows版本搭建安装React Native环境配置
参考:http://www.lcode.org/react-native/ React native中文网:http://reactnative.cn/docs/0.23/android-setup. ...
- VSTO学习笔记(三) 开发Office 2010 64位COM加载项
原文:VSTO学习笔记(三) 开发Office 2010 64位COM加载项 一.加载项简介 Office提供了多种用于扩展Office应用程序功能的模式,常见的有: 1.Office 自动化程序(A ...
- 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记
回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...
- ES6学习笔记<三> 生成器函数与yield
为什么要把这个内容拿出来单独做一篇学习笔记? 生成器函数比较重要,相对不是很容易理解,单独做一篇笔记详细聊一聊生成器函数. 标题为什么是生成器函数与yield? 生成器函数类似其他服务器端语音中的接口 ...
- angular学习笔记(三十一)-$location(2)
之前已经介绍了$location服务的基本用法:angular学习笔记(三十一)-$location(1). 这篇是上一篇的进阶,介绍$location的配置,兼容各版本浏览器,等. *注意,这里介绍 ...
- python3.4学习笔记(三) idle 清屏扩展插件
python3.4学习笔记(三) idle 清屏扩展插件python idle 清屏问题的解决,使用python idle都会遇到一个常见而又懊恼的问题——要怎么清屏?在stackoverflow看到 ...
- amazeui学习笔记三(你来我往1)--常见问题FAQs
amazeui学习笔记三(你来我往1)--常见问题FAQs 一.总结 1.DOM事件失败:记得加上初始化代码,例如 图片轮播 $('#my-slider').flexslider(); 2.jquer ...
- 物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus
物联网学习笔记三:物联网网关协议比较:MQTT 和 Modbus 物联网 (IoT) 不只是新技术,还是与旧技术的集成,其关键在于通信.可用的通信方法各不相同,但是,各种不同的协议在将海量“事物”连接 ...
随机推荐
- js跨域传值,兼容ie8以上
js跨域传值,兼容ie8以上 事先说明,此方法并不支持ie8,如果想要支持ie8的话,需要用这种思路(来自微软): if (window.addEventListener) { window.addE ...
- 试了下阿里云的OPEN Api
逐渐理解open api的意义,试了下阿里云的续费接口,续费一个月 package com.test; /** * @author * @date 2018/12/05 */ import com.a ...
- 生活实遇记-Kindle好久没用,屏幕一直处于电池状态,怎么解决?
2018-01-02 实遇记-Kindle好久没用,屏幕一直处于电池状态,怎么解决? 今天我翻腾出自己的kindle,好久没用了,屏幕一直是一个电池状态,充电头+线充了2个钟头,按电源键木有反应,也是 ...
- Android中五大字符串总结(String、StringBuffer、StringBuilder、Spanna
https://www.aliyun.com/jiaocheng/2861.html?spm=5176.100033.1.35.2ed56b03CbsYFK 摘要:String.StringBuffe ...
- C# 反编译
今儿也是运气背,不知怎么的,一脚就把电脑踢关机了(其实就轻轻碰到了一下主机),我去,写了一早上的代码,尼玛就不见,不见就算了,其实是保存了的,主要是文件还损坏了,尼玛,那心情!!! 然后就想着恢复,下 ...
- 吴裕雄 python深度学习与实践(8)
import cv2 import numpy as np img = cv2.imread("G:\\MyLearning\\TensorFlow_deep_learn\\data\\le ...
- Python利用PIL生成随机验证码图片
安装pillow: pip install pillow PIL中的Image等模块提供了创建图片,制作图片的功能,大致的步骤就是我们利用random生成6个随机字符串,然后利用PIL将字符串绘制城图 ...
- HTTPS SSL/TLS协议
要说清楚 HTTPS 协议的实现原理,至少需要如下几个背景知识.1. 大致了解几个基本术语(HTTPS.SSL.TLS)的含义2. 大致了解 HTTP 和 TCP 的关系(尤其是“短连接”VS“长连接 ...
- mysql修改EST时区,mysql时间修改
方法有两种 ###第一种 select NOW();show variables like "%time_zone%"; ##一:通过sql命令临时修改 set global ti ...
- python爬虫 scrapy框架(一)爬取壁纸照片
此项目仅供学习参考, 不用于任何商业用途 若侵权留言,立刻删除 刚入门爬虫不久,一心想找个网站试试,然后朋友推荐了这个壁纸网站