React Native -- unable to load script from assets 'index.android bundle'

1、问题描述

创建一个 React Native 项目后,用 Android Studio 运行 android 项目,结果跑出异常:
unable to load script from assets ‘index.android bundle’ ,make sure your bundle is packaged correctly or youu’re runing a packager server
在这里插入图片描述

2、解决方法

1、在android/app/src/main目录下新建一个assets文件夹

  • 可在 Android Studio 中建立
  • 可在终端中执行以下命令建立:
mkdir android/app/src/main/assets

2、在项目的根目录下,执行如下命令:

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

执行此命令后,在终端中抛出异常:
在这里插入图片描述
没有找到 index.adnroid.js 文件。
原因:
React Native 0.43 以上版本的目录结构已经变了,0.43以上已经将 index.adnroid.js 和 index.ios.js 合并为 index.js
React Native 0.43 版本以下项目目录结构:
在这里插入图片描述

React Native 0.43 版本以上项目目录结构:
在这里插入图片描述

所以:
React Native 0.43 版本以下,执行命令:

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 0.43 版本以上,执行命令:

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

执行成功后,会在 android/app/src/main/assets 目录下产生 index.android.bundle 文件
在这里插入图片描述

在 Android Studio 上再次运行,即可成功

3、总结

index.android.bundle 是用来调用原生控件的 js 脚本,每次改变了 index.android.js 或 index.js 时,都需要上面的代码片段,来及时更新 index.android.bundle,然后打包才可以把新的 index.android.js 或 index.js 应用上,所以当没有 index.android.bundle 文件时,Android Studio 上是无法运行 android 项目的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值