通过cordova将vue项目打包为webapp的方法


Posted in Javascript onFebruary 02, 2019

准备工作:需要之前配置好vue-cli脚架构,安装好cordova环境。下面开始对vue.js项目进行打包,打包环境为Android。

可以看下我的github:https://github.com/padipata ,里面有我自己写的vue项目,喜欢的给个关注呗。

1.添加cordova项目

$ cordova create myApp1 org.apache.cordova.myApp myApp2

其中:

  • myApp1:cordova目录名
  • org.apache.cordova.myApp: 包名
  • myApp2: 项目名(在config.xml的<name>中查看)

2.在vue中添加cordova的配置

myApp1/www/index.html----->vue/index.html

  • 将myApp1/www/index.html中所有的<meta>拷贝到vue/index.html中
  • 将myApp1/www/index.html中<script>关于cordova.js的引用拷贝到vue/index.html中

myApp1/www/js/index.js----->vue/vuex/main.js

var app = {
// Application Constructor
initialize: function() {
thisbindEvents();
},
// Bind Event Listeners
//
// Bind any events that are required on startup Common events are:
// 'load', 'deviceready', 'offline', and 'online'
bindEvents: function() {
documentaddEventListener('deviceready', thisonDeviceReady, false);
},
// deviceready Event Handler
//
// The scope of 'this' is the event In order to call the 'receivedEvent'
// function, we must explicitly call 'appreceivedEvent();'
onDeviceReady: function() {
appreceivedEvent('deviceready');
},
// Update DOM on a Received Event
receivedEvent: function(id) {
var parentElement = documentgetElementById(id);
var listeningElement = parentElementquerySelector('listening');
var receivedElement = parentElementquerySelector('received');
listeningElementsetAttribute('style', 'display:none;');
receivedElementsetAttribute('style', 'display:block;');
consolelog('Received Event: ' + id);
}
};
appinitialize();

1)内容拷贝到vue/src/vuex/main.js中

2)onDeviceReady时启动app

onDeviceReady: function () {
//appreceivedEvent('deviceready');
appRouterstart(App, 'app')
windownavigatorsplashscreenhide()
}

3.创建android项目

终端中进入到myApp1 项目,执行以下命令:

cordova platform add android这时候vue项目中会得到一个android文件夹,里面包含一个测试版本的apk,可以传输到手机上调试。

4.添加cordova插件

终端中进入到vue项目,执行以下命令:

cordova plugin add xxxx

5. 构建 vue项目

通过cordova将vue项目打包为webapp的方法

许多人掉过这个坑,打包出来的apk是一个cordova默认的空白项目,因此,需要在打包vue之前在这里把配置文件修改过来。 

终端中进入到vue项目,执行以下命令:npm run build

6.文件转移

将dist文件夹下的文件,拷贝到cordova/platforms/androd/assets/www目录下 (index.html替代掉原本的)

7.构建cordova项目

从终端进入到myApp1/platforms/android/cordova目录下,执行以下命令:

cordova build android //构建apk 

配置JDK环境(这里只对mac os进行记录,Win系统请自行脑补):

cd ~ 进入到~目录

touch .bash_profile

vi .bash_profile 使用vi编辑器编辑 .bash_profile文件

然后输入 i ,在vi编辑器里面输入 i 的意思是开始编辑。

vi编辑器里面的内容如下:

JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.7.0_79.jdk/Contents/Home
CLASSPAHT=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
PATH=$JAVA_HOME/bin:$PATH:
export JAVA_HOME
export CLASSPATH
export PATH 

然后退出vi编辑器使用如下命令:(个人习惯 :wq!回车)

1. 输入ese

2. 输入冒号: wq

3. 保存退出

如果以上修改完毕切正确,那么接下来就是让配置的环境变量生效,使用如下命令:source .bash_profile

完毕以后查看下当前的java 版本是否正确输入如下命令:java -version

如果是预想中的1.8,那么恭喜你,你这个时候就可以执行: cordova build android

cordova run android //构建apk,并安装到连接的设备上(按个人需求)

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

Javascript 相关文章推荐
Ext.FormPanel 提交和 Ext.Ajax.request 异步提交函数的区别
Nov 12 Javascript
基于jquery的页面划词搜索JS
Sep 14 Javascript
『jQuery』名称冲突使用noConflict方法解决
Apr 22 Javascript
node.js中使用node-schedule实现定时任务实例
Jun 03 Javascript
JavaScript获取网页、浏览器、屏幕高度和宽度汇总
Dec 18 Javascript
js检测判断日期大于多少天的方法
May 04 Javascript
第十章之巨幕页头缩略图与警告框组件
Apr 25 Javascript
javascript this详细介绍
Sep 19 Javascript
JavaScript计算值然后把值嵌入到html中的实现方法
Oct 29 Javascript
浅谈JavaScript中的apply/call/bind和this的使用
Feb 26 Javascript
Angular中的$watch、$watchGroup、$watchCollection
Jun 25 Javascript
vue组件中实现嵌套子组件案例
Aug 31 Javascript
用Cordova打包Vue项目的方法步骤
Feb 02 #Javascript
JS实现数组去重及数组内对象去重功能示例
Feb 02 #Javascript
JS实现的Object数组去重功能示例【数组成员为Object对象】
Feb 01 #Javascript
JavaScript动态创建二维数组的方法示例
Feb 01 #Javascript
Electron 如何调用本地模块的方法
Feb 01 #Javascript
详解使用webpack+electron+reactJs开发windows桌面应用
Feb 01 #Javascript
原来JS还可以这样拆箱转换详解
Feb 01 #Javascript
You might like
thinkPHP使用post方式查询时分页失效的解决方法
2015/12/09 PHP
HTML中嵌入PHP的简单方法
2016/02/16 PHP
PHP会员找回密码功能的简单实现
2016/09/05 PHP
PHP查询分页的实现代码
2017/06/09 PHP
PHP常用函数之获取汉字首字母功能示例
2019/10/21 PHP
php实现文件上传基本验证
2020/03/04 PHP
图片自动缩小 点击放大
2008/07/07 Javascript
javascript高亮效果的二种实现方法
2008/09/14 Javascript
重构Javascript代码示例(重构前后对比)
2013/01/23 Javascript
Js点击弹出下拉菜单效果实例
2013/08/12 Javascript
基于HTML5上使用iScroll实现下拉刷新,上拉加载更多
2016/05/21 Javascript
详解JavaScript对象类型
2016/06/16 Javascript
Js删除数组中某一项或几项的几种方法(推荐)
2016/07/27 Javascript
Select2.js下拉框使用小结
2016/10/24 Javascript
基于JavaScript实现熔岩灯效果导航菜单
2017/01/04 Javascript
Bootstrap table简单使用总结
2017/02/15 Javascript
BootStrap表单时间选择器详解
2017/05/09 Javascript
详解基于angular-cli配置代理解决跨域请求问题
2017/07/05 Javascript
浅谈JavaScript find 方法不支持IE的问题
2017/09/28 Javascript
JS+CSS实现网页加载中的动画效果
2017/10/27 Javascript
JavaScript实现音乐自动切换和轮播
2017/11/05 Javascript
vue开发环境配置跨域的方法步骤
2019/01/16 Javascript
JavaScript闭包与作用域链实例分析
2019/01/21 Javascript
Node.js API详解之 dns模块用法实例分析
2020/05/15 Javascript
python3 http提交json参数并获取返回值的方法
2018/12/19 Python
Python单元和文档测试实例详解
2019/04/11 Python
python装饰器使用实例详解
2019/12/14 Python
python实现输入三角形边长自动作图求面积案例
2020/04/12 Python
Mixbook加拿大:照片书,照片卡,剪贴簿,年历和日历
2017/02/21 全球购物
美国女孩服装购物网站:Justice
2017/03/04 全球购物
简短证婚人证婚词
2014/01/09 职场文书
授权委托书样本及填写说明
2014/09/19 职场文书
大连导游词
2015/02/12 职场文书
企业催款函范本
2015/06/24 职场文书
vue 把二维或多维数组转一维数组
2022/04/24 Vue.js
CSS使用SVG实现动态分布的圆环发散路径动画
2022/12/24 HTML / CSS