React Native bundle打离线包

2022-03-09 19:32:45 浏览数 (2)

react-native-cli 自带脚本可以打包 react-native bundle 命令

以下是命令的参数说明:

react-native bundle

  • –entry-file ,ios或者android入口的js名称
  • –platform ,平台名称(ios或者android)
  • –dev ,设置为false的时候将会对JavaScript代码进行优化处理
  • –bundle-output, 生成的jsbundle文件的名称,比如./ios/index.ios.jsbundle
  • –assets-dest 图片以及其他资源存放的目录,比如./ios 默认会生成一个新的文件夹assets
如果打ios的bundle 用以下命令
代码语言:javascript复制
react-native bundle --entry-file index.ios.js --bundle-output ./ios/main.jsbundle --platform ios --assets-dest ./ios --dev false

如果打Android的bundle 用以下命令 跟iOS差不多,把变量换成android

代码语言:javascript复制
react-native bundle --entry-file index.android.js --bundle-output ./android/app/src/main/assets/index.android.bundle --platform android --assets-dest ./android/app/src/main/res --dev false

利用npm的脚本也可以实现当前的效果,在package.json中添加如下:

代码语言:javascript复制
"scripts": {

    "start": "node node_modules/react-native/local-cli/cli.js start",

    "bundle-ios": "react-native bundle --entry-file index.ios.js --bundle-output ./ios/main.jsbundle --platform ios --assets-dest ./ios --dev false",

    "bundle-android": "react-native bundle --entry-file index.android.js --bundle-output ./android/app/src/main/assets/index.android.bundle --platform android --assets-dest ./android/app/src/main/res --dev false"

以后每次打包直接运行:

代码语言:javascript复制
npm run bundle-ios
npm run bundle-android

打包好的资源添加到xcode项目。

到具体的rn控制器中,采用bundle的方式集成 main和打出来的bundle前面的名称对应

代码语言:javascript复制
//  jsCodeLocation = [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index.ios" fallbackResource:nil];

  jsCodeLocation = [[NSBundle mainBundle] URLForResource:@"main" withExtension:@"jsbundle"];

0 人点赞