gulp可以自动压缩html/css/js静态资源文件,减少空间,加快网页打开速度。

gulp更新到4.0.2变更了语法,只需要把最后执行的代码 gulp.parallel 改成 gulp.series 即可。

BUG:butterfly主题更新到4.x后,会导致搜索功能无法使用,建议使用terser压缩方式。

//v3版本执行语法
gulp.task('default', gulp.parallel('compress', 'minify-css', 'minify-html', 'minify-images'))

//gulp 4.0.2新语法修改
gulp.task('default', gulp.series('compress', 'minify-css', 'minify-html'))

首先要安装gulp和插件:

#全局安装gulp指令集
npm install --global gulp-cli
#安装gulp插件
npm install gulp --save
#压缩html
npm install gulp-htmlclean --save-dev
#压缩HTML中的ES6语法
npm install gulp-html-minifier-terser --save-dev
#压缩CSS
npm install gulp-clean-css --save-dev
#压缩JS
npm install gulp-uglify --save-dev
npm install gulp-babel @babel/core @babel/preset-env --save-dev
npm install gulp-terser --save-dev
#压缩字体
npm install gulp-fontmin --save

在博客根目录创建gulpfile.js脚本文件,输入以下内容:

完整代码如下:

babel压缩JS
bug:可能导致搜索功能不可用,建议换成terser压缩方式

const gulp = require('gulp')
const cleanCSS = require('gulp-clean-css')
const htmlmin = require('gulp-html-minifier-terser')
const htmlclean = require('gulp-htmlclean')
const imagemin = import('gulp-imagemin')
const uglify = require('gulp-uglify')
const babel = require('gulp-babel')

// 压缩js
gulp.task('compress', () =>
gulp.src(['./public/**/*.js', '!./public/**/*.min.js'])
.pipe(babel({
presets: ['@babel/preset-env']
}))
.pipe(uglify().on('error', function (e) {
console.log(e)
}))
.pipe(gulp.dest('./public'))
)

// 压缩css
gulp.task('minify-css', () => {
return gulp.src('./public/**/*.css')
.pipe(cleanCSS())
.pipe(gulp.dest('./public'))
})

// 压缩public目录内html
gulp.task('minify-html', () => {
return gulp.src('./public/**/*.html')
.pipe(htmlclean())
.pipe(htmlmin({
removeComments: true, // 清除 HTML 註释
collapseWhitespace: true, // 压缩 HTML
collapseBooleanAttributes: true, // 省略布尔属性的值 <input checked="true"/> ==> <input />
removeEmptyAttributes: true, // 删除所有空格作属性值 <input id="" /> ==> <input />
removeScriptTypeAttributes: true, // 删除 <script> 的 type="text/javascript"
removeStyleLinkTypeAttributes: true, // 删除 <style> 和 <link> 的 type="text/css"
minifyJS: true, // 压缩页面 JS
minifyCSS: true, // 压缩页面 CSS
minifyURLs: true // 压缩页面 URL
}))
.pipe(gulp.dest('./public'))
})

// 压缩 public/uploads 目录内图片,一般用图片软件压缩就行
//gulp.task('minify-images', async () => {
// gulp.src('./public/img/**/*.*')
// .pipe(imagemin({
// optimizationLevel: 5, // 类型:Number 预设:3 取值範围:0-7(优化等级)
// progressive: true, // 类型:Boolean 预设:false 无失真压缩jpg图片
// interlaced: false, // 类型:Boolean 预设:false 隔行扫描gif进行渲染
// multipass: false // 类型:Boolean 预设:false 多次优化svg直到完全优化
// }))
// .pipe(gulp.dest('./public/img'))
//})

// v3版本语法,执行gulp命令时执行的任务
//gulp.task('default', gulp.parallel('compress', 'minify-css', 'minify-html', 'minify-images'))

// gulp 4.0.2新语法
gulp.task('default', gulp.series('compress', 'minify-css', 'minify-html'))

tester压缩JS(推荐)

var gulp = require('gulp');
var cleanCSS = require('gulp-clean-css');
var htmlmin = require('gulp-html-minifier-terser');
var htmlclean = require('gulp-htmlclean');
var fontmin = require('gulp-fontmin');
// gulp-tester
var terser = require('gulp-terser');

// 压缩js
gulp.task('compress', async() =>{
gulp.src(['./public/**/*.js', '!./public/**/*.min.js'])
.pipe(terser())
.pipe(gulp.dest('./public'))
});

//压缩css
gulp.task('minify-css', () => {
return gulp.src(['./public/**/*.css'])
.pipe(cleanCSS({
compatibility: 'ie11'
}))
.pipe(gulp.dest('./public'));
});

//压缩html
gulp.task('minify-html', () => {
return gulp.src('./public/**/*.html')
.pipe(htmlclean())
.pipe(htmlmin({
removeComments: true, //清除html注释
collapseWhitespace: true, //压缩html
collapseBooleanAttributes: true,
//省略布尔属性的值,例如:<input checked="true"/> ==> <input />
removeEmptyAttributes: true,
//删除所有空格作属性值,例如:<input id="" /> ==> <input />
removeScriptTypeAttributes: true,
//删除<script>的type="text/javascript"
removeStyleLinkTypeAttributes: true,
//删除<style>和<link>的 type="text/css"
minifyJS: true, //压缩页面 JS
minifyCSS: true, //压缩页面 CSS
minifyURLs: true //压缩页面URL
}))
.pipe(gulp.dest('./public'))
});

//压缩字体
function minifyFont(text, cb) {
gulp
.src('./public/fonts/*.ttf') //原字体所在目录
.pipe(fontmin({
text: text
}))
.pipe(gulp.dest('./public/fontsdest/')) //压缩后的输出目录
.on('end', cb);
}

gulp.task('mini-font', (cb) => {
var buffers = [];
gulp
.src(['./public/**/*.html']) //HTML文件所在目录请根据自身情况修改
.on('data', function(file) {
buffers.push(file.contents);
})
.on('end', function() {
var text = Buffer.concat(buffers).toString('utf-8');
minifyFont(text, cb);
});
});

// 运行gulp命令时依次执行以下任务
gulp.task('default', gulp.series(
'compress', 'minify-css', 'minify-html','mini-font'
))

最后命令用法:

hexo clean
hexo generate
gulp
hexo server 或 hexo deploy

参考文章:
使用gulp压缩博客静态资源