【前端】Vue和Vux开发WebApp日志三、完善gulp任务
转载请注明出处:http://www.cnblogs.com/shamoyuu/p/vue_vux_3.html
项目github地址:https://github.com/shamoyuu/vue-vux-iconan
我们继续完善我们常用的几个任务。
首先把在安卓手机上运行的任务独立出来
'cordova.run.android': () => {
shelljs.cd('./dist');
shelljs.exec('cordova run android');
shelljs.cd(__dirname);
}
然后修改run.android任务,在最后面添加cordova.run.android
'run.android': () => {
runSequence(
'clean.dist',
'copy.cordova',
'webpack.build',
'cordova.run.android'
)
}
执行一下,跟原来执行的一样一样。
然后我们新建一个build.android方法,来打出apk的包,不过在这之前,我们先要完成2件事
首先我们现在来生成一个安卓的证书文件iconan.keystore。
在CMD里执行
keytool -genkey -alias iconan -keyalg RSA -validity 20000 -keystore iconan.keystore
然后设置一些秘密、姓名、公司名、地址等等的信息就可以了,最后生成的iconan.keystore文件可能在java/bin文件夹下,也可能在C:\Users\[用户名]下。然后把这个文件复制到我们项目的根目录。
然后在项目根目录新建一个build.json文件,用来存放打包的一些信息
{
"android": {
"debug": {
"keystore": "./iconan.keystore",
"storePassword": "123456",
"alias": "iconan",
"password" : "123456",
"keystoreType": ""
},
"release": {
"keystore": "./iconan.keystore",
"storePassword": "123456",
"alias": "iconan",
"password" : "123456",
"keystoreType": ""
}
}
}
然后开始添加cordova.build.android的gulp任务
'cordova.build.android': () => {
shelljs.cd('./dist');
shelljs.exec('cordova build android --buildConfig=../build.json');
shelljs.cd(__dirname);
}
然后添加build.android任务
'build.android': () => {
runSequence(
'clean.dist',
'copy.cordova',
'webpack.build',
'cordova.build.android'
)
}
可以看到build.android和run.android非常相似,只有最后一个任务不同,这就是使用gulp和runSequence比较好的方面,可以自己组合出不同的任务。
然后我们添加dev任务,用来开发的时候用
首先添加gulp-shell插件,这个跟shelljs不太一样,我们用来它执行一些其他指令
npm install gulp-shell --save-dev
然后在gulpfile.js文件引入
const shell = require('gulp-shell');
然后给tasks添加dev,不过它不再是个function,顺便把它当成default方法
//默认任务
'default': ['dev'],
//开发模式
'dev': shell.task([
'webpack-dev-server --inline --progress --config build/webpack.dev.conf.js'
]),
但是这样启动会报错
Module build failed: Error: "extract-text-webpack-plugin" loader is used without the corresponding plugin, refer to https://github.com/webpack/extract-text-webpack-plugin for the usage example
根据报错提示,访问https://github.com/webpack/extract-text-webpack-plugin 可以得到解决办法
打开webpack.dev.conf.js文件,添加extract-text-webpack-plugin的引用
const ExtractTextPlugin = require('extract-text-webpack-plugin');
然后devWebpackConfig的plugins添加
new ExtractTextPlugin("styles.css")
其他不用动,然后删除package.json文件里的scripts属性,因为我们现在完全可以用gulp来处理
【前端】Vue和Vux开发WebApp日志三、完善gulp任务的更多相关文章
- 【前端】Vue和Vux开发WebApp日志四、增加命令行参数
转载请注明出处:http://www.cnblogs.com/shamoyuu/p/vue_vux_4.html 项目github地址:https://github.com/shamoyuu/vue- ...
- 【前端】Vue和Vux开发WebApp日志一、整合vue+cordova和webpack+gulp
转载请注明出处:http://www.cnblogs.com/shamoyuu/p/vue_vux.html 项目github地址:https://github.com/shamoyuu/vue-vu ...
- 【前端】Vue和Vux开发WebApp日志二、优化gulp任务
转载请注明出处:http://www.cnblogs.com/shamoyuu/p/vue_vux_2.html 项目github地址:https://github.com/shamoyuu/vue- ...
- Web前端-Vue.js必备框架(三)
Web前端-Vue.js必备框架(三) vue是一款渐进式javascript框架,由evan you开发.vue成为前端开发的必备之一. vue的好处轻量级,渐进式框架,响应式更新机制. 开发环境, ...
- 团队开发前端VUE项目代码规范
团队开发前端VUE项目代码规范 2018年09月22日 20:18:11 我的小英短 阅读数 1658 一.规范目的: 统一编码风格,命名规范,注释要求,在团队协作中输出可读性强,易维护,风格一致 ...
- 如何优雅的使用vue+vux开发app -03
如何优雅的使用vue+vux开发app -03 还是一个错误的示范,但是离优雅差的不远了... <!DOCTYPE html> <html> <head> < ...
- 如何优雅的使用vue+vux开发app -02
如何优雅的使用vue+vux开发app -02 很明显这又是一个错误的示范,请勿模仿 使用动态组件实现保留状态的路由 <!DOCTYPE html> <html> <he ...
- 如何优雅的使用vue+vux开发app -01
如何优雅的使用vue+vux开发app -01 很明显下面是个错误的示范: <!DOCTYPE html> <html> <head> <title>v ...
- vue 开发系列(三) vue 组件开发
概要 vue 的一个特点是进行组件开发,组件的优势是我们可以封装自己的控件,实现重用,比如我们在平台中封装了自己的附件控件,输入控件等. 组件的开发 在vue 中一个组件,就是一个独立的.vue 文件 ...
随机推荐
- grep使用技巧一:模式pattern为字符串文件
pattern文件: antc areq bdos bogt …… igs.txt文件: abmf 298.4725 16.2623 abpo 47.2292 -19 ...
- PHP定义字符串的四种方式
1.简介 在PHP中这门语言中,因为是弱类型语言,因此使用变量时不需提前定义即可使用. 我们在使用php进行开发的时候,大多数使用双引号.单引号进行定义字符串.既然有这两种方式,那么他们之间肯定是有区 ...
- 【AIX】AIX内存机制
[AIX]AIX内存机制 1 虚拟内存 虚拟内存是物理内存和交换空间(Paging Space)组合形成的虚拟内存空间, 通过虚拟的地址空间映射到物理内存或者 Paging Space. 在 AIX ...
- JVM学习(二)
Java中的内存的划分可以用下图来表示: 程序计数器:每一个线程都有一个程序计数器,记录需要执行的下一条指令. HootSpot虚拟机中,不区分虚拟机栈和本地方法栈,统一称为栈.虚拟机栈和本地方法栈也 ...
- python基础 列表 的使用
列表 首先定义一个列表 声明列表 列表名字=[值1,值2] list=[1,2,3,4,5] 这是一个列表,列表中有五个元素(1,2,3,4,5) 显示list列表 print list 输出 ...
- CF698C. LRU [容斥原理 概率]
CF698C. LRU 题意:n种物品,大小为k的队列,\(p_i\)的概率选择第i种物品放入队尾,如果已经有i了就不放了.队列大小>k时弹出队首.求\(10^{100}\)次操作后每种物品在队 ...
- MarkDown 编辑数学公式
1. 参考博客:http://blog.csdn.net/smstong/article/details/44340637 1 数学公式的web解决方案 在网页上显示漂亮的数学公式,是多年来数学工作者 ...
- mac qq怎么删除全部聊天记录
找到 ./Users/user/Library/Containers/com.tencent.qq/ 删除com.tencent.qq文件夹就行.
- iOS UIFont 字体名字大全
Font Family: American TypewriterFont: AmericanTypewriterFont: AmericanTypewriter-Bold Font Family: A ...
- Docker Centos7 下建立 Docker 桥接网络
为什么要让docker桥接物理网络? docker默认提供了一个隔离的内网环境,启动时会建立一个docker0的虚拟网卡,每个容器都是连接到docker0网卡上的.而docker0的ip段为172.1 ...