9.使用gulp对资源进行压缩
2024/10/25:gulp已经更新了5.0,我所使用的配置文件中所用的gulp-fontmin是在目前为止是过时的插件,除非安装gulp4,不然以下配置文件大概率会出现不可预料的错误。
在 Web 前端开发工作中有很多“重复工作”,比如压缩CSS/JS文件。而这些工作都是有规律的。找到这些规律,并编写 gulp 配置代码,让 gulp 自动执行这些“重复工作”。— form gulp-book!
什么是gulp
Gulp 是一个流行的自动化构建工具,用于简化这些重复性的任务。Gulp 的核心思想是利用代码来自动化处理开发过程中的繁琐任务,从而提高开发效率和代码质量。
正如官网上所说:
“A toolkit to automate & enhance your workflow"
"Leverage gulp and the flexibility of JavaScript to automate slow, repetitive workflows and compose them into efficient build pipelines.”
而Gulp 的强大之处在于它的插件生态系统。插件是用于处理特定任务的 JavaScript 模块。我们可以安装部分插件来使我们完成对博客静态资源的压缩。
安装gulp
gulp是基于node.js开发的,我们需要先安装node.js和npm,npm会在安装完node.js后自动安装。 安装完成后看看是否安装成功。
# 检查安装node -vnpm -v我使用hexo来建站,hexo本身需要依托node.js,所以使用hexo的朋友可以跳过安装node.js这一步。
安装 Gulp 的命令行工具,这样可以使我们在命令行中使用gulp。
npm install -g gulp-cli# 检查版本gulp -v安装插件
gulp拥有着丰富的插件支持,其中就有我们所需要的压缩网页的插件。
# 安装 gulpnpm install gulp --save-dev# 删除无用文件npm install gulp-clean --save-dev# 压缩和优化 CSSnpm install gulp-clean-css --save-dev# 压缩字体文件npm install gulp-fontmin --save-dev# 压缩和优化 HTML 文件npm install gulp-html-minifier-terser --save-dev# 清理和格式化 HTML 文件npm install gulp-htmlclean --save-dev# 压缩和混淆 JavaScript 文件npm install gulp-terser --save-dev# 用于将 TrueType 字体文件 (.ttf) 转换为 WOFF2 格式npm install gulp-ttf2woff2 --save-dev使用
安装完成后,在博客根目录新建gulpfile.js,并且输入以下内容
// 引入所需的插件const gulp = require('gulp');const htmlmin = require('gulp-html-minifier-terser');const htmlclean = require('gulp-htmlclean');const cleanCSS = require('gulp-clean-css');const terser = require('gulp-terser');const fontmin = require('gulp-fontmin');const ttf2woff2 = require('gulp-ttf2woff2');const clean = require('gulp-clean');
// 压缩和清理 HTMLgulp.task('minify-html', () => { return gulp.src('./public/**/*.html')// 看情况修改 .pipe(htmlclean()) .pipe(htmlmin({ collapseWhitespace: true , removeComments: true, //清除html注释 collapseWhitespace: true, //折叠文档树中构成文本节点的空白区域 collapseBooleanAttributes: true, //省略布尔属性的值,例如:<input checked="true"/> ==> <input /> removeEmptyAttributes: true, //删除所有空格作属性值,例如:<input id="" /> ==> <input /> removeScriptTypeAttributes: true, //删除<script>的type="text/javascript" removeStyleLinkTypeAttributes: true, //删除<style>和<link>的 type="text/css" removeAttributeQuotes: true, // 移除属性值周围的引号 removeCDATASectionsFromCDATA: true, // 从 CDATA 部分移除注释 caseSensitive: true, // 以区分大小写的方式处理属性 minifyJS: true, //压缩页面 JS minifyCSS: true, //压缩页面 CSS minifyURLs: true , //压缩页面URL })) .pipe(gulp.dest('./public'))// 看情况修改});
// 压缩 CSSgulp.task('minify-css', () => { return gulp.src(['./public/**/*.css'])// 看情况修改 .pipe(cleanCSS({ level: { 2: { mergeAdjacentRules: true, // 控制相邻规则的合并,默认为 true mergeIntoShorthands: true, // 控制属性合并为简写形式,默认为 true mergeMedia: true, // 控制 @media 规则的合并,默认为 true mergeNonAdjacentRules: true, // 控制非相邻规则的合并,默认为 true mergeSemantically: false, // 控制语义合并,默认为 false overrideProperties: true, // 基于可读性控制属性覆盖,默认为 true removeEmpty: true, // 控制删除空规则和嵌套块,默认为 true reduceNonAdjacentRules: true, // 控制非相邻规则的缩减,默认为 true removeDuplicateFontRules: true, // 控制删除重复的 @font-face 规则,默认为 true removeDuplicateMediaBlocks: true, // 控制删除重复的 @media 规则,默认为 true removeDuplicateRules: true, // 控制删除重复的规则,默认为 true removeUnusedAtRules: false, // 控制删除未使用的 at 规则,默认为 false(自版本 4.1.0 起可用) restructureRules: false, // 控制规则重构,默认为 false skipProperties: [] // 控制不进行优化的属性,默认为 [],即所有属性都进行优化(自版本 4.1.0 起可用) } } })) .pipe(gulp.dest('./public'));// 看情况修改});
// 压缩 JavaScriptgulp.task('compress', async() =>{ return gulp.src(['./public/**/*.js', '!./public/**/*.min.js'])// 看情况修改 .pipe(terser()) .pipe(gulp.dest('./public'));// 看情况修改});
//读取文章使用字体,然后压缩gulp.task('mini-font', (cb) => { var buffers = []; gulp .src(['./public/**/*.html']) // 看情况修改 .on('data', function(file) { buffers.push(file.contents); }) .on('end', function() { var text = Buffer.concat(buffers).toString('utf-8'); minifyFont(text, cb); });});
//压缩字体function minifyFont(text, cb) { gulp .src('./public/font/*.ttf') //原字体所在目录 .pipe(fontmin({ text: text })) .pipe(gulp.dest('./public/fonts/')) //压缩后的输出目录 .on('end', cb);}
// 定义转换 TTF 到 WOFF2 的任务gulp.task('convertFonts', function() { return gulp.src('./public/fonts/*.ttf')// 看情况修改 .pipe(ttf2woff2()) .pipe(gulp.dest('./public/fonts/'));// 看情况修改});
//删除字体原文件,主题生成的图片文件gulp.task('clean-files', function() { return gulp.src(['./public/font','./public/images'], { read: false, allowEmpty: true })// 看情况修改 .pipe(clean());});
// 运行gulp命令时依次执行以下任务gulp.task('default', gulp.series( gulp.parallel('compress', 'minify-css', 'minify-html', 'mini-font',), 'convertFonts',// 在 'mini-font' 完成后执行 'convertFonts',最后执行clean-files 'clean-files'))运行和小小的改进
重新渲染一次,并执行gulp,接下来就可以看到gulp压缩后的效果了。
hexo clhexo ggulphexo s上图为gulp执行前后的文件大小对比图,其中public为未执行gulp指令,public-gulp为执行gulp指令。
下图两者均去除字体文件和images文件夹后只对比html,css,js的大小。

可以看出,在去除字体文件和images文件夹后,其他的文件压缩了大约100kb的大小o_o …。但是在网站中占大头的字体文件却是狠狠的压缩了,总算是不用担心网站打开速度被字体拖慢了.
尽管从上图看,字体的压缩看似是从15MB降低至了8MB,但其实在tff2woff2所转化的字体文件夹中,会同时将tff转化为 .eot , .woff2 , .woff , .ttf , .svg 多个字体格式,从而做到各个网站的适配。
而目前主流浏览器大多使用woff2格式,也就是说,我们打开网页的时候,大概率是使用woff2字体,如果不去适配IE和低版本浏览器,大概也可以再将字体文件删除。
下边的代码块是只保留woff2字体删除其他字体的。虽然没什么用,毕竟浏览器是按照样式表来下载字体的,多余的字体文件不会被下载,留在这里也没什么影响。。
gulp.task('clean-files', function() { return gulp.src([ './public/font', './public/images', './public/fonts/yourfont.eot', './public/fonts/yourfont.ttf', './public/fonts/yourfont.svg', './public/fonts/yourfont.woff',// 看情况修改字体名字 ], { read: false, allowEmpty: true }) .pipe(clean());});附上一张不使用任何处理,只是用ttf2woff2处理字体后,输出文件夹字体占用大小截图,可以看到,svg居然占到了丧心病狂的4M,而woff2只有699kb,删了会清爽很多。

注意事项
ttf2woff2 会在指定目录生成一个文件夹,其中会有’字体文件名字.css’的css文件,将它引入即可使用转化后的字体文件。
使用gulp压缩字体必须在本地进行,进一步导致本地文件增大,看着有点难受。我有在想,是否可以做到当博客仓库提交的时候自动触发action,拉取字体文件进行处理,然后博客再通过网络引入该css,从而做到public文件夹的干净。但是最后实在是不想折腾,也就放弃了。
我所使用的图片均由外链引入,不需要hexo的images文件夹,所以使用clean-files时顺便将其删除。如需使用images,请自行修改。当然,gulp也有与压缩图片有关的插件,可自行搜索使用。
更详细的设置请参考所用插件的官方文档。
评论
评论加载中...