data:image/s3,"s3://crabby-images/84a85/84a858c92f06f21be609996b6a4c9d63cfdc8185" alt=""
前言
Vue打包至移动端目前已经有许多解决方案,例如HBuilder、Cordova等等。但个人认为过程实在是太过于繁杂,且有的还需要联网验证,于是有了这篇文章。原理就是利用原生Android WebView本地加载Vue打包后的静态HTML,本文章以Android为例,使用Android Studio本地打包,IOS端同理。
准备
工具:Android Studio
源码:npm run build
之后的静态资源,例如dist
文件夹
步骤
1. 打开Android Studio
data:image/s3,"s3://crabby-images/d6c1e/d6c1ea69d0fbd447b045b2eacfdf0e2c523b7272" alt="Open image"
2. 新建项目 New Project - Empty Activity - Next
填写Name(应用名称)、Package Name(包名)、Language(以Kotlin为例)、Minimum SDK(应用支持的最低Android版本),然后点击Finish创建项目。初次安装AS并创建项目需要联网下载Gradle等依赖,请耐心等待。
data:image/s3,"s3://crabby-images/9480a/9480af88b12f400adc0b3755a7922cddc643c31b" alt="New image"
3. 主题设置为NoActionBar
默认主题会有一个ActionBar,需要去掉以保证加载后的Vue UI统一性。
首先在左侧打开themes下的两个主题文件,其中一个是深色模式的主题,我们需要将两个都改为NoActionBar。这里以浅色模式为例。
data:image/s3,"s3://crabby-images/f86ed/f86ed23eb839eaae9fb90531a8db331f7a01fb08" alt="ActionBar image"
↓
data:image/s3,"s3://crabby-images/5d75a/5d75a64e2c2be9053a781f3fe039939d4c0b5fee" alt="NoActionBar image"
4. 设置状态栏背景颜色
同样,在浅色模式主题文件中,修改android:statusBarColor
为你想要的颜色,并将状态栏文字图标等设为深色
1 | <item name="android:windowLightStatusBar">true</item> |
data:image/s3,"s3://crabby-images/693b4/693b4a65ac06eafeb6c32915be17956a1a0c6e9a" alt="statusBarColor image"
深色模式同理。
data:image/s3,"s3://crabby-images/283c0/283c089eb39bcb7968b033dc5b8f9bb5e281a22c" alt="statusBarColorDark image"
5. 布局添加WebView
打开activity_main.xml
:
data:image/s3,"s3://crabby-images/6881b/6881bb6cff052ddf11d3fcc72071a196ebc44cf4" alt="activity_main image"
删除TextView并添加WebView:
1 | <WebView |
data:image/s3,"s3://crabby-images/daf96/daf964bf8fb73f545c2e793d1d1252e03244eff7" alt="WebView image"
6. 本地加载打包后的HTML
在项目目录下app\src\main
创建assets
文件夹,将打包后的dist放入assets:
data:image/s3,"s3://crabby-images/bd610/bd61078a2caad6dc43c2a2d8d8add6c7f0e421bb" alt="assets image"
打开MainActivity.kt
data:image/s3,"s3://crabby-images/0108a/0108ad5cef50d6f0d77a902331d39bfb2a1a9961" alt="MainActivity image"
绑定组件:
1 | val webView: WebView = findViewById(R.id.web_view) |
本地加载HTML:
1 | webView.loadUrl("file:////android_asset/dist/index.html") |
允许JS交互:
1 | webView.settings.javaScriptEnabled = true |
data:image/s3,"s3://crabby-images/33a21/33a21c3b61a4086ad2683f2e5224e566e60bda56" alt="code image"
打开AndroidManifest.xml
:
data:image/s3,"s3://crabby-images/caac2/caac253a2e426f95f99adddf87b04aed7a225314" alt="AndroidManifest image"
添加INTERNET权限:
1 | <uses-permission android:name="android.permission.INTERNET" /> |
data:image/s3,"s3://crabby-images/ca81e/ca81e7315a51a9b984585271038d965596451d7d" alt="INTERNET image"
8. 更换APP图标
左栏右键res - drawable - New - Image Asset
data:image/s3,"s3://crabby-images/abc0d/abc0d9faca310574c7fd059a8309cec857109da0" alt="icon_1 image"
配置图标前景、背景:
data:image/s3,"s3://crabby-images/4d03d/4d03dde905f5de9e508ca2fe7e0ed8346315efbd" alt="icon_2 image"
data:image/s3,"s3://crabby-images/6f504/6f5041408a9feb77c95a404a170f3d5152e18cf8" alt="icon_3 image"
Next - Finish
data:image/s3,"s3://crabby-images/c76b5/c76b5e7196b0f615860ac23b90dad90ece9912af" alt="icon_4 image"
删除ic_launcher.webp
、ic_launcher_round.webp
(如果有的话)
data:image/s3,"s3://crabby-images/5d0de/5d0de41979fb01759bb14ac916522d6bdd5ea910" alt="icon_5 image"
data:image/s3,"s3://crabby-images/e8e27/e8e271ca6d5bfd230d441bf640244645bb79a740" alt="icon_6 image"
data:image/s3,"s3://crabby-images/de5ff/de5ffee1b9bb299cffe3b5dde2eb4bec81d8be58" alt="icon_7 image"
data:image/s3,"s3://crabby-images/16562/16562a65a04a8b72d40b6e030259253fe1e77bd2" alt="icon_8 image"
7. 调试
1) Android调试
以真机调试为例,当然也可以使用模拟器。
真机调试需要在开发者模式开启USB调试模式。
点击右上方绿色三角形运行。
data:image/s3,"s3://crabby-images/b4d4b/b4d4bcc0f7ece5f0cc000cd02cfca52d863d15b2" alt="run image"
稍等片刻,会自动启动APP:
data:image/s3,"s3://crabby-images/0b1d5/0b1d59687c64a6b1faa915a9665af3e4bfffb85d" alt="app_0 image"
data:image/s3,"s3://crabby-images/d713b/d713ba4cce37c44b51e4eecefebe57fdee6fbb8f" alt="app_1 image"
2) WebView调试
需要在开发者模式开启USB调试模式。
在MainActivity.kt
中添加以下代码:
1 | WebView.setWebContentsDebuggingEnabled(true) |
data:image/s3,"s3://crabby-images/c1e44/c1e44f8b4d4991f28f67d6b0686f9d79b112912c" alt="debug image"
重新在AS中调试运行App,打开谷歌浏览器,地址栏输入:chrome://inspect/#devices
进入远程调试工具。
稍等片刻工具会自动载入已运行的WebView程序,点击inspect
进入调试模式。
data:image/s3,"s3://crabby-images/282c5/282c5e1eefe95685ae5eaa80b655ffad9be311a2" alt="devices image"
8. 编译并签名
点击工具栏 Build - Generate Signed Bundle / APK …
data:image/s3,"s3://crabby-images/637c0/637c09ea212b9a7799f3a7a69dda64d68d7709fa" alt="generate image"
选择APK - Next
data:image/s3,"s3://crabby-images/b099b/b099ba18f78e9878865d27addc0ee38f39488aeb" alt="next image"
新建签名 Create new… 填写签名信息
data:image/s3,"s3://crabby-images/aede2/aede259e3d10f075851e6238e6624bdb157974aa" alt="newjks image"
选择刚刚创建的签名文件 xxx.jks 填写对应信息后点击 Next
data:image/s3,"s3://crabby-images/c895d/c895d733075d2cf6aff95684a52bed4c9809e49e" alt="sign image"
data:image/s3,"s3://crabby-images/3cc7d/3cc7d79d495615f2d6ee2091084e3b8dec10fd65" alt="sign image"
选择release并点击Finish
data:image/s3,"s3://crabby-images/e73da/e73da883a1b665b9218fdd0a61674eb26612a51b" alt="sign_finish image"
项目目录下app\release
即是编译完成的apk文件。
data:image/s3,"s3://crabby-images/06d1b/06d1b49845b74b3076fd27d7b7916a0de0b93933" alt="successfully image"
data:image/s3,"s3://crabby-images/d0226/d02266ca34bf7a203fa26e8ecd64c82c24900dda" alt="release image"
9. 常见问题
1) 跨域
建议从后端解决跨域问题,以Flask为例:
1 | pip3 install flask-cors |
1 | from flask import Flask |
2) WebView调试出现ERR_CLEARTEXT_NOT_PERMITTED
data:image/s3,"s3://crabby-images/68d97/68d97b9692bf26ad04707460c86bd42a166e90a3" alt="ERR_CLEARTEXT_NOT_PERMITTED image"
打开AndroidManifest.xml
,在application
标签下配置:
1 | <application |