如何使用cordova打包vue项目
一.准备环境1.安装node和npm;#npm2.安装好vue环境:3.安装好cordova,官网链接地址:http://cordova.axuer.com/#getstarted#npm install -g cordova二.建立项目1. 建立vue项目;2. 在vue的项目文件目录中建立一个cor...
·
一.准备环境
1.安装node和npm;
#npm
2.安装好vue环境:
3.安装好cordova,官网链接地址:http://cordova.axuer.com/#getstarted
#npm install -g cordova
二.建立项目
1. 建立vue项目;
2. 在vue的项目文件目录中建立一个cordova项目
#cordova create path(文件夹名字)id(应用id名字)name(应用名字)
exmple:cordova create myproject com.example.myproject testpro
(这个时候能在vue目录中多了文件夹)
#cd 文件夹名字
#cordova platform add ios
#cordova platform add android
(运行add或者remove平台的命令将会影响项目 platforms的内容,在这个目录中每个指 定平台都有一个子目录)
#cordova platform ls (检查你当前平台设置状况)
【注意:我使用的设备是mac,由于androidsdk的gredla版本太低就报错,解决办法是下载一个最新的版本https://gradle.org/install/ ;
然后配置Gradle环境;
我的本机Gradle路径是 /Users/xxx/Downloads/gradle-4.6;
1.打开mac终端,在终端中输入:open -e .bash_profile,打开.bash_profile文件;如果报错说没有这个文件,就新建一个vim ~/.bash_profile;
2.编辑.bash_profile文件,在.bash_profile文件中输入下面内容:
GRADLE_HOME=/Users/xxx/gradle/gradle-3.3;(Gradle的本机路径)
export GRADLE_HOME
export PATH=$PATH:$GRADLE_HOME/bin
3.保存.bash_profile文件,在终端上执行source ~/.bash_profile,更新.bash_profile文件,在终端上执行gradle -version,查看是否配置成功。重新进入到vue的cordova目录运行#cordova platform ls】
要构建和运行App,你需要安装每个你需要平台的SDK;
三.准备打包工作
1.首先修改vue项目的index.html,在head之间加入
<meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *; img-src 'self' data: content:;">
<meta name="format-detection" content="telephone=no">
<meta name="msapplication-tap-highlight" content="no">
<meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
注意:加入<meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *; img-src 'self' data: content:;">这个可能导致页面样式改变,如果改变则不加,否则还是建议加上。这段主要是防止跨站脚本攻击。
引入cordova.js
<body>
<div id="app"></div>
<script type="text/javascript" src="cordova.js"></script>
<!-- built files will be auto injected -->
</body>
然后修改src中的main.js为以下代码
// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import App from './App'
import router from './router'
Vue.config.productionTip = false
/* eslint-disable no-new */
document.addEventListener('deviceready', function() {
new Vue({
el: '#app',
router,
store,
template: '<App/>',
components: { App }
})
window.navigator.splashscreen.hide()
}, false);
最后修改config文件夹中的index.js文件,修改build中的
assetsSubDirectory: 'static',
assetsPublicPath: '/',
为
assetsSubDirectory: '',
assetsPublicPath: '',
运行
#npm run dev
看看是否能够运行起来,如果正常说明到这里是没有问题的(注意这里运行的时候需要将document.addEventListener注释,因为在浏览器环境下是找不到cordova.js的也就不能监听到deviceready的事件,打包在真机上才能实现监听)。
四.打包
1.先在vue项目中运行
#npm run build
执行完成后会生成一个dist文件夹,找到这个文件夹将里面的所有文件复制到你的cordova项目的www文件夹下替换它原有的文件。然后就可以执行
2.cordova目录中运行
#cordova build android
会生成一个可执行的apk文件,安装即可。到这里就完成了我们vue项目的打包。
【注意:如果vue项目在运行npm run dev或者npm run build的时候遇到问题一般不是代码出错的话可以将node_modules文件夹删除使用npm install安装。
如果是因为eslint导致代码检查不通过的话,可以将Vue项目的build文件夹下的webpack.base.config文件中的rules
{
test: /\.(js|vue)$/,
loader: 'eslint-loader',
enforce: 'pre',
include: [resolve('src'), resolve('test')],
options: {
formatter: require('eslint-friendly-formatter')
}
},
注释就好】
更多推荐
已为社区贡献1条内容
所有评论(0)