Gulp - 压缩HTML、CSS、JavaScript 程式码
前言
在网站正式上线前,压缩程式码是必要的过程,因为可以节省空间还能提高网页整体的效能,这里会介绍三压缩程式码的套件,分别是gulp-htmlmin 、gulp-clean-css、gulp-terser。
安装
套件连结:gulp-htmlmin、gulp-clean-css、gulp-terser
gulp-htmlmin 安装指令:
npm install gulp-htmlmingulp-clean-css 安装指令:
npm install gulp-clean-cssgulp-terser 安装指令:
npm install gulp-terser --save-dev你可能会在其他地方看到有人使用gulp-minify-css 套件进行CSS压缩,但这套件已被弃用,这里推荐使用gulp-clean-css。
基本使用
初始专案结构:
gulp-demo/
│
├─── node_modules/
|
├─── public/
|
├─── source/
│ │
│ └─── css/
│ │
│ └─── style.css // CSS 主档案
│ │
│ └─── js/
│ │
│ └─── main.js // JavaScript 主档案
│ │
│ └─── index.html // HTML 主档案
│
├─── gulpfile.js // Gulp 配置档案
├─── package-lock.json
└─── package.json载入并使用套件:
// 引入套件及套件api
const gulp = require("gulp");
const htmlmin = require("gulp-htmlmin");
const cleanCSS = require("gulp-clean-css");
const terser = require("gulp-terser");
// 任务一压缩HTML
function minify_html() {
return gulp
.src("source/*.html")
.pipe(
htmlmin({
collapseWhitespace: true,
})
)
.pipe(gulp.dest("public/"));
}
// 任务二压缩CSS
function minify_css() {
return gulp
.src("source/css/*.css")
.pipe(
cleanCSS({
compatibility: "ie8",
})
)
.pipe(gulp.dest("public/css"));
}
// 任务三压缩JavaScript
function minify_javascript() {
return gulp.src("source/js/*.js")
.pipe(terser({
compress: {
drop_console: true,
},
}))
.pipe(gulp.dest("public/js"));
}
//输出任务
exports .default = gulp.parallel(minify_html, minify_css, minify_javascript);执行任务指令:
gulpgulp-htmlmin 可传递选项
可参考gulp-htmlmin Options可传递选项列表,以下是常用配置:
- collapseWhitespace: true/false折叠空白字元,默认为false。
- removeComments: true/false删除HTML 注解,默认为false。
function minify_html() {
return gulp
.src("source/*.html")
.pipe(
htmlmin({
collapseWhitespace: true,
removeComments: true
}))
.pipe(gulp.dest("public/"));
}gulp-clean-css 可传递选项
可参考gulp-clean-css Options可传递选项列表,以下是常用配置:
- compatibility: *、ie9、ie8、ie7兼容模式,默认 * 为IE10 以上
- level: 0、1、2优化级别,默认为1
function minify_css() {
return gulp
.src("source/css/*.css")
.pipe(
cleanCSS({
compatibility: "ie8",
level: 2
})
)
.pipe(gulp.dest("public/css"));
}gulp-terser 可传递选项
可参考gulp-terser Options可传递参数列表,以下是常用配置:
- compress: 参考Compress Options,传递一个对象以指定自定义压缩选项,默认为{}。此范例 drop_console:true 会放弃对 console.* 的调用,默认为false。
function minify_javascript() {
return gulp.src("source/js/*.js")
.pipe(terser({
compress: {
drop_console: true,
},
}))
.pipe(gulp.dest("public/js"));
}本文内容仅供个人学习/研究/参考使用,不构成任何决策建议或专业指导。分享/转载时请标明原文来源,同时请勿将内容用于商业售卖、虚假宣传等非学习用途哦~感谢您的理解与支持!