使用 gulp 对资源进行压缩
在 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 后自动安装。
安装完成后看看是否安装成功。
1 | # 检查安装 |
我使用 hexo 来建站,hexo 本身需要依托 node.js,所以使用 hexo 的朋友可以跳过安装 node.js 这一步。
安装 Gulp 的命令行工具,这样可以使我们在命令行中使用 gulp。
1 | npm install -g gulp-cli |
安装插件
gulp 拥有着丰富的插件支持,其中就有我们所需要的压缩网页的插件。
1 | # 安装 gulp |
使用
安装完成后,在博客根目录新建 gulpfile.js
,并且输入以下内容
1 | // 引入所需的插件 |
运行和小小的改进
重新渲染一次,并执行 gulp,接下来就可以看到 gulp 压缩后的效果了。
1 | hexo cl |
上图为 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 字体删除其他字体的。虽然没什么用,毕竟浏览器是按照样式表来下载字体的,多余的字体文件不会被下载,留在这里也没什么影响。。
1 |
|
附上一张不使用任何处理,只是用 ttf2woff2 处理字体后,输出文件夹字体占用大小截图,可以看到,svg 居然占到了丧心病狂的 4M,而 woff2 只有 699kb,删了会清爽很多。
注意事项
ttf2woff2
会在指定目录生成一个文件夹,其中会有’字体文件名字.css’的 css 文件,将它引入即可使用转化后的字体文件。
使用 gulp 压缩字体必须在本地进行,进一步导致本地文件增大,看着有点难受。我有在想,是否可以做到当博客仓库提交的时候自动触发 action,拉取字体文件进行处理,然后博客再通过网络引入该 css,从而做到 public 文件夹的干净。但是最后实在是不想折腾,也就放弃了。
我所使用的图片均由外链引入,不需要 hexo 的 images 文件夹,所以使用 clean-files 时顺便将其删除。如需使用 images,请自行修改。当然,gulp 也有与压缩图片有关的插件,可自行搜索使用。
更详细的设置请参考所用插件的官方文档。