這篇文章講我整理的一種打包項目的方式,如下是個人依賴清單css
"devDependencies": { "gulp": "^3.9.1", "gulp-asset-rev": "0.0.15", "gulp-clean-css": "^2.1.3", "gulp-htmlmin": "^3.0.0", "gulp-notify": "^2.2.0", "gulp-uglify": "^2.0.0" }
這裏僅供參考,不少都已經有更新的版本了。若是不想本身下載的,能夠npm install個人。html
下載完畢後,找到node_modules --> gulp-assets-rev -->index.js 修改成以下代碼:node
var verStr = (options.verConnecter || "") + md5; src=src+"?v="+verStr;
gulpfile.js:npm
先引用:gulp
var gulp = require('gulp'); var htmlmin = require('gulp-htmlmin'); var notify = require('gulp-notify'); var cleancss = require('gulp-clean-css'); var uglify = require('gulp-uglify'); var assetRev = require('gulp-asset-rev');
CSS壓縮,輸出ui
gulp.task('minifyCss', function() { return gulp.src('src/css/*.css') .pipe(assetRev()) .pipe(cleancss({compatibility: 'ie8'})) .pipe(gulp.dest('dist/css')) .pipe(notify({ message: 'CSS文件壓縮完畢' })); });
壓縮js文件,輸出spa
gulp.task('minifyJs', function() { return gulp.src('src/js/*.js') .pipe(assetRev()) .pipe(uglify()) .pipe(gulp.dest('dist/js')) .pipe(notify({ message: 'js文件混縮完畢' })); });
HTML壓縮,輸出code
gulp.task('minifyHtml',function() { return gulp.src('src/*.html') .pipe(assetRev()) .pipe(htmlmin({collapseWhitespace: true})) .pipe(gulp.dest('dist')) .pipe(notify({ message: 'HTML文件壓縮完畢' })); });
整合htm
gulp.task('default', function(){ gulp.run('minifyCss', 'minifyJs','minifyHtml'); // 監聽html文件變化 gulp.watch('src/*.html', function(){ gulp.run('minifyHtml'); }); //監聽CSS文件變化 gulp.watch('src/css/*.css', function(){ gulp.run('minifyCss','minifyHtml'); }); //監聽JS文件變化 gulp.watch('src/js/*.js', function(){ gulp.run('minifyJs','minifyHtml'); }); });
調用:blog
gulp
這篇文章就到這裏了,但願對你有所幫助。