使用GULP打包、壓縮與打版本號

 這篇文章講我整理的一種打包項目的方式,如下是個人依賴清單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

這篇文章就到這裏了,但願對你有所幫助。

相關文章
相關標籤/搜索