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

在打包之前,确保环境安装成功,各方面都没有错误,不然会吃很多苦头,关于其他的环境安装我会在另外一篇文章中记录。本文中所有操作皆是在vscode中操作。

第一步:安装cordova

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

npm install -g cordova

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

第二步:新建cordova项目

执行命令

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

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

cordova -v

检查一下版本号,可能出现问题

You have been opted out of telemetry. To change this, run: cordova telemetry on.

解决方法

cordova telemetry on
cordova -v
6.5.0
$ cordova platforms add android --save
Using cordova-fetch for cordova-android@^7.1.4
Platform android already added.

Platform android already added. 这一步完成后,在项目platforms文件夹下会发现多了文件夹,本人是Android环境,打包后的项目名是android。到这说明vue和cordova整合已经成功了。

测试一下整体环境是否正确:cordova requirements

如果android环境不正确,这里会报错

第三步:修改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

看看是否能够运行起来,如果正常说明到这里是没有问题的(注意这里运行的时候需要将document.addEventListener注释,因为在浏览器环境下是找不到cordova.js的也就不能监听到deviceready的事件,打包在真机上才能实现监听)。

第四步:将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')}},

这段代码注释即可。

用Cordova打包Vue项目为app相关推荐

  1. 使用Cordova打包Vue项目为IOS并使用XCode提交到AppStore

    打包Vue项目 1.在Webstorm中打开Vue项目,在下面的Terminal中输入: npm run build 2.等待build完成,双击项目,进入菜单选择Reveal in Finder , ...

  2. Cordova打包Vue项目(修改APP logo name)

    修改log 可参考官方链接 https://cordova.apache.org/docs/en/9.x/config_ref/images.html 准备四张png格式的需要替换的logo图片,大小 ...

  3. 亲测用APICloud打包vue项目

    准备工作: 1.去APICloud官网下载打包工具 https://www.apicloud.com/devtools 我使用的是第三款(Eclipse APICloud Plugins(Studio ...

  4. 使用webpack打包vue项目

    使用webpack打包vue项目 安装webpack工具,安装方式有两种:全局安装(命令:npm install -g webpack webpack-cli)以及安装在项目中,这里使用第二种: // ...

  5. webpack打包vue项目之后dist文件夹在本地跑起来

    webpack打包vue项目之后dist文件夹在本地跑起来 转载为:https://blog.csdn.net/u014054437/article/details/79981307 谢谢博主 亲测, ...

  6. vue项目某个APP页面实现手机物理按键返回、路由拦截、localStorage存取参数

    vue项目某个APP页面实现手机物理按键返回.路由拦截.localStorage存取参数 最近做个功能:在web系统里面嵌套两个app页面,当然APP页面在web系统上没有路由跳转,而是从另外系统扫码 ...

  7. vue打包部署到php,打包vue项目部署在nginx

    因为liunx操作命令不是很熟,我整的是宝塔面板部署哈 首先在本地打包vue项目,打包成功后,项目中会多出一个dist 文件夹 把dist上传到服务器 配置nginx配置文件,新建一个othercon ...

  8. webStorm 打包Vue项目

    webStorm打包vue项目 之前在网上看到过好多打包vue项目的方法,感觉不是很全面,最后自己总结了一下. 首先,如果需要打包的话,你需要改下资源的路径 1.打开build下面的utils.js文 ...

  9. WebStorm打包Vue项目

    WebStorm打包Vue项目 修改资源路径 build下的utils.js文件: if (options.extract) {return ExtractTextPlugin.extract({us ...

最新文章

  1. Java集合框架之fastutil
  2. 1099 Build A Binary Search Tree (30 分)【难度: 一般 / 知识点: 建立二叉搜索树】
  3. vue axios 跨域_SpringBoot+Vue从零开始搭建系统(三)前后端整合二
  4. 设计模式的理解:享元模式 (Flyweight)
  5. docker build 中的上下文路径
  6. python表格写操作单元格合并
  7. java并发初探CountDownLatch
  8. java采集温湿度水浸_智能电力水浸监控解决方案
  9. HDOJ 1754 I Hate It 解题报告
  10. 写给新入IT的新人们(转载)
  11. harmonyos鸿蒙,HarmonyOS鸿蒙入门篇
  12. Hadoop上路-03_Hadoop JavaAPI
  13. Efficient and Effective Data Imputation with Influence Functions
  14. WPF 计算DataGrid每一列的合计数
  15. Linux计划任务篇
  16. laravel excel导入导出box/spout
  17. 自制ip地址切换器ip.dat
  18. 2019前端最全面试题
  19. 用户需求说明书和产品规格需求说明书的区别
  20. jq 异步如何变成同步

热门文章

  1. php validate,jQuery Validate | 菜鸟教程
  2. Android Mvc 模式
  3. 14-受控组件和非受控组件使用
  4. 全国青少年编程等级考试python一级真题2020年6月(含题库答题软件账号)
  5. 微信JSAPI几个函数介绍
  6. 5年后端WEB开发者的开机必备软件
  7. GitHub两天标星2.1K+!自动刷喵币靠这一个脚本就够了.....
  8. 【算法入门必刷】数据结构-栈(一)
  9. 社区,v2ex;天才,livid and SAI
  10. NETDMIS5.0位置度评价案例1