最近一段时间一直在作桌面混合应用,跟以往作web端不一样的是,没法再经过在浏览器上输入内部的域名来随时跟踪开发版本的情况了,只能经过打包代码让产品或领导随时跟踪进度。node
这里就涉及到一些问题了:es6
1,须要打包成zip文件便于传输web
2,须要排除一些仅是开发中须要的文件,如node_modules,一些没必要要的config等npm
而后,首当其冲gulp,关于gulp和grunt的比较,流式(stream)操做比较快之类的云云就很少废话了。json
一,生成zip文件gulp
使用gulp-zip插件数组
首先是安装浏览器
npm install gulp -g
npm install gulp gulp-zip --save-dev
这里存在两个问题:babel
{ ...//此处省略100行 "main": "src/js/index.js", "scripts": { "zip": "gulp zip" }, ...//此处省略100行 }
如此就能够不用全局安装gulp了,由于npm-script会自动到local的node_modules目录中查找到gulp命令。grunt
安装完了以后,就开始编写gulpfile.js(若是要使用es6语法,需更名为gulpfile.babel.js,并需安装babel,题外话,不展开):
const gulp = require('gulp'); const zip = require('gulp-zip'); gulp.task('zip', function() { return gulp.src('**/*.*') .pipe(zip('test.zip')) .pipe(gulp.dest('export')); });
gulp的使用问题不在这里赘述。而后就能够在根目录下运行
gulp zip
或使用npm-script方式
npm run zip
而后就在export/下能看到你导出的test.zip文件,里面包含了根目录下的全部文件。
二,排除某些不须要的目录和文件
一些常见的须要排除的目录有node_modules,本地config等,gulp.src提供了强大的路径匹配,咱们都知道src能接受数组来作多个匹配。
一开始你可能会这样写:
gulp.src(['!**/node_modules/**/*.*','!config/**/*.*'])
而后就出错了:Error: Missing positive glob
原来反匹配在gulp.src中是不能够写在第一位的,第一项必定是正匹配,因而这样写:
gulp.src(['**/*.*','!**/node_modules/**/*.*','!config/**/*.*'])
一切大吉了,压缩出来的文件不包含这些文件夹里的东西了。也许你要问,就排除个文件夹,为何不能直接写**/node_modules?据我实验下来,这边过滤的只能是文件而不是一个路径,若是你只写路径,是没有效果的,必须匹配到该路径下的全部文件。