经过几天的努力终于实现了一个完美的作品,webpack可以与gulp完美结合的进行打包静态文件,并将静态文件上传到七牛云存储,当然也可以传到你想传的云存储了,这里只分享一个七牛的云存储方案。
关于如何使用webpack打包静态代码,这个可以参考我之前的一些文章和方案,不行的话可以进群交流。
这里只分享一下gulp这边的操作,然后给一个例子实现如何一条命令打包静态文件并更新cdn文件的方法。
先展示一下gulpfile.js文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
| const gulp = require('gulp'); const uglify = require('gulp-uglify'); const concat = require('gulp-concat'); const shrink = require('gulp-cssshrink'); const webpack = require('gulp-webpack'); const qn = require('gulp-qn');
const rev = require('gulp-rev-qn'); const revCollector = require('gulp-rev-collector'); const runSequence = require('run-sequence'); const config = require('./webpack.config'); const qiniu_options = { accessKey: 'xxx', secretKey: 'xxx', bucket: 'xxx', domain: 'http://xxx.com' }; gulp.task('publish-js', function () { return gulp.src(['./build/js/*.js']) .pipe(uglify()) .pipe(rev()) .pipe(gulp.dest('./build/js')) .pipe(qn({ qiniu: qiniu_options, prefix: 'js' })) .pipe(rev.manifest()) .pipe(gulp.dest('./build/rev/js')); }); gulp.task('publish-font-img', function () { return gulp.src(['./build/js/*.svg','./build/js/*.gif','./build/js/*.woff2','./build/js/*.ttf','./build/js/*.eot','./build/js/*.woff']) .pipe(qn({ qiniu: qiniu_options, prefix: 'js' })); }); gulp.task('publish-css', function () { return gulp.src(['./build/js/*.css']) .pipe(rev()) .pipe(gulp.dest('./build/js')) .pipe(qn({ qiniu: qiniu_options, prefix: 'css' })) .pipe(rev.manifest()) .pipe(gulp.dest('./build/rev/css')); }); gulp.task('publish-html', function () { return gulp.src(['./build/rev/**/*.json', './build/views/*.html']) .pipe(revCollector({ dirReplacements: { '/js/': '' } })) .pipe(gulp.dest('./build/views')); }); gulp.task('default',function(callback){ runSequence( ['publish-css','publish-js','publish-font-img'], 'publish-html', callback); });
|
publish-js部分是将我的js文件进行版本更新并上传到七牛。
publish-font-img部分是将我的字体文件、图片文件上传到七牛
publish-css部分是将我的css文件进行版本更新并上传到七牛
publish-html将我html文件中对应的js路径进行替换,好了,可以直接发布这个build文件夹下的文件了。