教你用Cordova打包Vue项目的方法


Posted in Javascript onOctober 17, 2017

现在国内越来越多的开发者使用Vue开发混合app,但是当大家开发完成过后才发现不知道该怎么将Vue项目打包成app。
据我现在的了解打包Vue项目目前流行的就是使用weex和cordova。weex是阿里提供并且Vue的作者也极力推荐的,有兴趣的可以去学习使用一下。因为我本身是做angular+ionic的,所以比较青睐cordova,下面我就教大家怎么使用cordova打包Vue项目:

第一步:安装cordova

如果已经安装则直接跳过,否则执行以下命令:

npm install -g cordova

如果这个命令都不会运行,那我建议你不要继续往下看了。

第二步:新建cordova项目

执行命令

cordova create cordovaApp com.cordova.testapp
cd cordovaApp
cordova platform add android

到这里我们的cordova项目就创建好了。

第三步:修改vue项目

如果你没有vue项目的话,自行百度去新建一个vue项目吧。

首先修改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

看看是否能够运行起来,如果正常说明到这里是没有问题的。

第四步:将vue文件放到cordova项目中并打包

先在vue项目中运行

npm run build

执行完成后会生成一个dist文件夹,找到这个文件夹将里面的所有文件复制到你的cordova项目的www文件夹下替换它原有的文件。

然后就可以执行

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')
       }
      },

这段代码注释即可。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
IE与Firefox下javascript getyear年份的兼容性写法
Dec 20 Javascript
仿163填写邮件地址自动显示下拉(无优化)
Nov 05 Javascript
DIY jquery plugin - tabs标签切换实现代码
Dec 11 Javascript
js实现俄罗斯方块小游戏分享
Jan 31 Javascript
JavaScript中的some()方法使用详解
Jun 09 Javascript
js实现人民币大写金额形式转换
Apr 27 Javascript
js判断价格,必须为数字且不能为负数的实现方法
Oct 07 Javascript
微信小程序 HTTPS报错整理常见问题及解决方案
Dec 14 Javascript
详解express + mock让前后台并行开发
Jun 06 Javascript
JQuery特殊效果和链式调用操作示例
May 13 jQuery
利用JavaScript将Excel转换为JSON示例代码
Jun 14 Javascript
微信小程序如何访问公众号文章
Jul 08 Javascript
vue与TypeScript集成配置最简教程(推荐)
Oct 17 #Javascript
基于匀速运动的实例讲解(侧边栏,淡入淡出)
Oct 17 #Javascript
javascript 中模板方法单例的实现方法
Oct 17 #Javascript
vue滚动轴插件better-scroll使用详解
Oct 17 #Javascript
react中的ajax封装实例详解
Oct 17 #Javascript
实现图片首尾平滑轮播(JS原生方法—节流)
Oct 17 #Javascript
打造通用的匀速运动框架(实例讲解)
Oct 17 #Javascript
You might like
php array_filter除去数组中的空字符元素
2020/06/21 PHP
一个简单的网页密码登陆php代码
2012/07/17 PHP
Yii的CDbCriteria查询条件用法实例
2014/12/04 PHP
Laravel中前端js上传图片到七牛云的示例代码
2017/09/04 PHP
LNMP部署laravel以及xhprof安装使用教程
2017/09/14 PHP
javascript 冒号 使用说明
2009/06/06 Javascript
JS正则中的RegExp对象对象
2012/11/07 Javascript
一个网页标题title的闪动提示效果实现思路
2014/03/22 Javascript
javascript正则匹配汉字、数字、字母、下划线
2014/04/10 Javascript
使用node.js半年来总结的 10 条经验
2014/08/18 Javascript
jQuery中ready事件用法实例
2015/01/19 Javascript
avalonjs实现仿微博的图片拖动特效
2015/05/06 Javascript
基于jQuery+JSON的省市二三级联动效果
2015/06/05 Javascript
浅析javascript函数表达式
2016/02/10 Javascript
JS实现的表头列头固定页面功能示例
2017/01/10 Javascript
bootstrap table单元格新增行并编辑
2017/05/19 Javascript
vue2 自定义动态组件所遇到的问题
2017/06/08 Javascript
vue+vue-validator 表单验证功能的实现代码
2017/11/13 Javascript
在vue项目中引入highcharts图表的方法
2019/01/21 Javascript
vue实现随机验证码功能(完整代码)
2019/12/10 Javascript
python根据出生日期返回年龄的方法
2015/03/26 Python
在Python中测试访问同一数据的竞争条件的方法
2015/04/23 Python
Python 程序报错崩溃后如何倒回到崩溃的位置(推荐)
2020/06/23 Python
详解基于python的全局与局部序列比对的实现(DNA)
2020/10/07 Python
凯伦·米莲女装网上商店:Karen Millen
2017/11/07 全球购物
Gerry Weber德国官网:优质女性时装,德国最大的时装公司之一
2019/11/02 全球购物
人事专员岗位职责
2013/11/20 职场文书
机修工工作职责
2014/02/21 职场文书
视光学专业自荐信
2014/06/24 职场文书
暑假安全教育广播稿
2014/09/10 职场文书
临时工聘用合同协议书
2014/10/29 职场文书
导游欢送词
2015/01/31 职场文书
初中毕业生感言
2015/07/31 职场文书
教你用python控制安卓手机
2021/05/13 Python
解决Tkinter中button按钮未按却主动执行command函数的问题
2021/05/23 Python
Go语言编译原理之变量捕获
2022/08/05 Golang