日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Taro打包Android?apk過程詳解_Android

作者:廈門在乎科技 ? 更新時間: 2022-04-12 編程語言

首先,我們使用使用命令創建模板項目,創建的命令如下。

taro init myApp

然后,使用 yarn 或者 npm install安裝依賴包,并使用下面的命令編譯Taro項目。

yarn dev:rn

啟動后會開啟一個監聽的進程。

不過,細心的你可能會發現,使用taro init命令初始化的項目是沒有原生模塊支持的,原來Taro使用了一個殼子工程,首先使用下面的命令下載殼子工程taro-native-shell,如下所示。

git clone git@github.com:NervJS/taro-native-shell.git

在taro-native-shell個目錄使用 yarn 或者 npm install 安裝依賴,并使用下面的命令啟動殼子工程。

react-native run-android

不過,啟動后報了如下的錯誤:

error: bundling failed: NotFoundError: Cannot find entry file index.js in any of the roots: ["/Users/mac/Taro/work/taro-yanxuan"]
    at DependencyGraph.getAbsolutePath (/Users/mac/Taro/work/taro-yanxuan/node_modules/metro/src/node-haste/DependencyGraph.js:317:11)
    at /Users/mac/Taro/work/taro-yanxuan/node_modules/metro/src/DeltaBundler/DeltaCalculator.js:280:416
    at Generator.next (<anonymous>)
    at step (/Users/mac/Taro/work/taro-yanxuan/node_modules/metro/src/DeltaBundler/DeltaCalculator.js:11:445)
    at /Users/mac/Taro/work/taro-yanxuan/node_modules/metro/src/DeltaBundler/DeltaCalculator.js:11:605
    at processTicksAndRejections (internal/process/task_queues.js:97:5)
上面報錯的意思是找不到RN的入口文件index.js。對于這個問題,只需要將 MainApplication.java 里面的 getJSMainModuleName 修改改為:

rn_temp/index

即可,因為Taro打的包在rn_temp目錄下,最新的 react-native-shell 已修復。

修改后,重新執行react-native run-android命令。

不過,由于項目是0.60.0版本以下的,所以我在運行的時候又報了下面的錯誤。

React Native version mismatch
javascript version 0.55.4
Native version 0.64.0

這是因為react-native-shell 是0.64.0,而我的RN項目是0.55.4,所以只能升級RN項目或者降級
react-native-shell 。如果沒有任何錯誤,接下來就可以制作離線的apk包了。
首先,你需要生成Android的密鑰文件,關于如何生成密鑰文件,可以自行查找相關的資料,把生成的密鑰文件拷貝到工程中的android/app文件夾中。然后,在在/android/gradle.properties中添加如下常量代碼。

MYAPP_RELEASE_STORE_FILE=my-release-key.keystore
MYAPP_RELEASE_KEY_ALIAS=my-key-alias
MYAPP_RELEASE_STORE_PASSWORD=*****
MYAPP_RELEASE_KEY_PASSWORD=*****

然后,在app/build.gradle文件中添加如下代碼。

release {
            if (project.hasProperty('MYAPP_UPLOAD_STORE_FILE')) {
                storeFile file(MYAPP_UPLOAD_STORE_FILE)
                storePassword MYAPP_UPLOAD_STORE_PASSWORD
                keyAlias MYAPP_UPLOAD_KEY_ALIAS
                keyPassword MYAPP_UPLOAD_KEY_PASSWORD
            }
        }

接下來,把前面生成的rn_temp文件復制到taro-native-shell殼子工程的android文件夾下,修改MainApplication里面的代碼,如下所示。

@Override
    protected String getBundleAssetName()  {
      return "./android/rn_temp/index";
    }
  };

然后,在android/app/build.gradle中修改添加如下代碼。

project.ext.react = [
        entryFile: "android/rn_temp/index.js",
        cliPath:"node_modules/react-native/cli.js"
]

然后,執行如下命令執行生成index.bundle 文件,如下所示。

node ./node_modules/react-native/local-cli/cli.js bundle --entry-file ./android/rn_temp/index.js --bundle-output ./android/rn_temp/index.bundle --assets-dest ./rn_bundle --dev false

最后,在Android的根目錄下執行打包命令。

./gradlew assembleRelease

打包完成后,就可以在android/app/build/outputs中看到簽名包。

原文鏈接:https://blog.csdn.net/weixin_41996102/article/details/119868143

欄目分類
最近更新