主要用于将开发好的网页打包成APP,支持的平台有:Android、IOS、Blackberry 十、OS X、Ubuntu、Windows、WP8。官网javascript
npm i cordova -g
复制代码
cordova create 项目名称
复制代码
可添加的平台:Android、IOS、Blackberry 十、OS X、Ubuntu、Windows、WP8 运行前须要配置平台的sdk,配置方法就不详细描述了,官网都有详细的说明。 cordova platform add 平台名html
cordova platform add android
复制代码
插件搜索页 cordova plugin add 插件名vue
示例: 添加热更新插件java
cordova plugin add cordova-hot-code-push-plugin
复制代码
运行前须要配置平台的sdk,配置方法就不详细描述了。Android配置node
cordova run 平台名
复制代码
示例:cordova run android 运行安卓android
该操做会将cordova项目下的www目录打包成网页;webpack
cordova build 平台名
复制代码
npm install --global vue-cli
复制代码
注意:在cordova项目下新建项目github
vue init webpack 项目名
复制代码
在vue项目下执行web
npm i
复制代码
在vue项目下执行
npm run build
复制代码
在vue项目下执行
npm run dev
复制代码
打开vue项目下的config/index.js文件按图指示修改文件
更改vue下的index.html文件,在添加如下内容。
<script src="cordova.js"></script>
复制代码
在vue目录下执行vue的打包命令,而后回到cordvoa目录下运行打cordova的打包命令。
每次测试的时候先要,在vue下输入npm run build,而后在输入cordova run build,这里咱们经过自定义脚本整合这两个命令。
1. 更改vue下的package.json 以下面的代码所示:在最后加入一条("android": "npm run build && cordova run android"),这句话等同于在命令行中输入npm run build && cordova run android
...
"scripts": {
"dev": "node build/dev-server.js",
"start": "node build/dev-server.js",
"build": "node build/build.js",
"unit": "cross-env BABEL_ENV=test karma start test/unit/karma.conf.js --single-run",
"e2e": "node test/e2e/runner.js",
"test": "npm run unit && npm run e2e",
"lint": "eslint --ext .js,.vue src test/unit/specs test/e2e/specs",
"android": "npm run build && cordova run android"
}
...
复制代码
2. 运行 命令行输入npm run 自定义的脚本名,示例:npm run android
1. 添加自动更新插件
cordova plugin add cordova-hot-code-push-plugin
复制代码
2. 开发环境依赖 不安装该插件会致使,本地运行后网页得不到更新。
cordova plugin add cordova-hot-code-push-local-dev-addon
复制代码
3. 安装自动更新客户端,一台电脑只须要安装一次。
npm install -g cordova-hot-code-push-cli(使用见发布更新)
复制代码
在cordova项目跟目录下新建该文件。
key | 含义 | 说明 |
---|---|---|
content_url | 项目地址 | 放在服务器上的项目地址 |
update | 更新方式 | app的更新方式 |
update的可选值
值 | 含义 |
---|---|
start | app启动时更新,默认为该值 |
resume | app从后台回复时更新 |
now | 下载完成后当即更新 |
示例
{
"update": "start",
"content_url": "http://60.205.169.27:80/cordovaDemo/www"
}
复制代码
在cordova项目根目录下为该文件添加新的配置,在config-file中填写chcp.json的地址,默认位置为www/chcp.json。
<widget>
...
<chcp>
<auto-download enabled="true" />
<auto-install enabled="true" />
<config-file url="http://60.205.169.27:80/cordovaDemo/www/chcp.json" />
<!--发布时更改成false,不然更新没法使用。-->
<local-development enabled="true" />
</chcp>
...
</widget>
复制代码
两个方法配合使用,先获取更新信息,而后在安装更新。
方法名 | 做用 |
---|---|
fetchUpdate | 获取更新信息 |
installUpdate | 自动下载并安装更新 |
开发过程当中会遇到一些错误,见error 详情
document.addEventListener('deviceready', () => {
let chcp = window.chcp
chcp.fetchUpdate(function (error, data) {
if (!error) {
chcp.installUpdate((err) => {
let msg = '更新成功'
if (err) {
msg = JSON.stringify(err)
}
window.alert(msg)
})
} else {
if (error.code === 2) {
window.alert('无更新')
} else {
window.alert(`error:${JSON.stringify(error)};data:${JSON.stringify(data)}`)
}
}
})
}, false)
复制代码