在虚拟机中运行老以为缺点什么,此次准备试试真机调试。本觉得会很顺利,结果碰一鼻子灰。按照文档的说法:react
结果在手机中运行后报这个错:android
怎么搞都没用。折腾了2天多!终于找出办法。
1,设置好 usb调试以后,先开一个 cmd 运行:adb devicesreact-native
2,查到 设备以后再开一个cmd:运行 adb reverse tcp:8081 tcp:8081app
3,执行上一步成功以后 继续开cmd 在此运行:react-native bundle --platform android --dev false --entry-file index.js --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res 这个是主要所在,后面修改以后的覆盖也要先执行一次这个命令 再 run 才会在手机上有改变!tcp
执行run 以后手机会跳出来是否安装应用,点击继续:就能够看效果了。测试
真是小坑坑死人,这个问题,网上几乎找不到答案,恰好我这放出来。
分割线=======================================================================================================================================================分割线
最后贴一下 另外一种错误的解决方法,也是真机中可能会遇到坑:
Mac中真机测试React Native project时出现Unable to load script from assets 'index.android.bundle'
第一步:首先切到咱们工程的根目录下,而后在android/app/src/main目录下新建一个assets文件夹,能够在终端中执行如下命令创建:spa
mkdir android/app/src/main/assets调试
固然也能够在Android Studio中手动创建;orm
第二步:一样须要在咱们工程的根目录下,执行如下命令:blog
react-native bundle --platform android --dev false --entry-file index.android.js --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res
第三步:从新运行如下命令便可:
react-native run-android
然而,这样并无解决上述问题,依然报错,且此时会出现另一个问题:
Cannot find entry file index.android.js in any of the roots: ["/Users//ReactNativeProjects/FirstReactApp"]
这时咱们去assets文件夹下才发现,第二步的命令并无在assets文件夹中生成咱们所需的文件,里面没有任何文件生成,此时笔者继续查找,在Stack Overflow中找到了解决方法,用下面的命令替换刚才第二步的命令:
react-native bundle --platform android --dev false --entry-file index.js --bundle-output android/app/src/main/assets/index.android.bundle --assets-dest android/app/src/main/res
原来是index.android.js已经改为index.js,难怪找不到呢!!!
使用上述命令后,此时在assets文件夹下会多出index.android.bundle和index.android.bundle.meta两个文件;
再从新运行工程就行了