精通gulp常用插件
发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,匹配符 *、**、!、{}gulp.src('./js/*.js') // * 匹配js文件夹下所有.js格式的文件gulp.src('./js/**/*.js')
千家信息网最后更新 2025年12月01日精通gulp常用插件
匹配符 *、**、!、{}
gulp.src('./js/*.js') // * 匹配js文件夹下所有.js格式的文件gulp.src('./js/**/*.js') // ** 匹配js文件夹的0个或多个子文件夹gulp.src(['./js/*.js','!./js/index.js']) // ! 匹配除了index.js之外的所有js文件gulp.src('./js/**/{omui,common}.js') // {} 匹配{}里的文件名文件操作
del (替代gulp-clean)
var del = require('del');del('./dist'); // 删除整个dist文件夹gulp-rename
描述:重命名文件。
var rename = require("gulp-rename");gulp.src('./hello.txt') .pipe(rename('gb/goodbye.md')) // 直接修改文件名和路径 .pipe(gulp.dest('./dist')); gulp.src('./hello.txt') .pipe(rename({ dirname: "text", // 路径名 basename: "goodbye", // 主文件名 prefix: "pre-", // 前缀 suffix: "-min", // 后缀 extname: ".html" // 扩展名 })) .pipe(gulp.dest('./dist'));gulp-concat
描述:合并文件。
var concat = require('gulp-concat');gulp.src('./js/*.js') .pipe(concat('all.js')) // 合并all.js文件 .pipe(gulp.dest('./dist')); gulp.src(['./js/demo1.js','./js/demo2.js','./js/demo2.js']) .pipe(concat('all.js')) // 按照[]里的顺序合并文件 .pipe(gulp.dest('./dist'));gulp-filter
描述:在虚拟文件流中过滤文件。
var filter = require('gulp-filter');const f = filter(['**', '!*/index.js']);gulp.src('js/**/*.js') .pipe(f) // 过滤掉index.js这个文件 .pipe(gulp.dest('dist'));const f1 = filter(['**', '!*/index.js'], {restore: true});gulp.src('js/**/*.js') .pipe(f1) // 过滤掉index.js这个文件 .pipe(uglify()) // 对其他文件进行压缩 .pipe(f1.restore) // 返回到未过滤执行的所有文件 .pipe(gulp.dest('dist')); // 再对所有文件操作,包括index.js压缩
gulp-uglify
描述:压缩js文件大小。
var uglify = require("gulp-uglify");gulp.src('./hello.js') .pipe(uglify()) // 直接压缩hello.js .pipe(gulp.dest('./dist')) gulp.src('./hello.js') .pipe(uglify({ mangle: true, // 是否修改变量名,默认为 true compress: true, // 是否完全压缩,默认为 true preserveComments: 'all' // 保留所有注释 })) .pipe(gulp.dest('./dist'))gulp-csso
描述:压缩优化css。
var csso = require('gulp-csso');gulp.src('./css/*.css') .pipe(csso()) .pipe(gulp.dest('./dist/css'))gulp-html-minify
描述:压缩HTML。
var htmlminify = require('gulp-html-minify');gulp.src('index.html') .pipe(htmlminify()) .pipe(gulp.dest('./dist'))gulp-p_w_picpathmin
描述:压缩图片。
var p_w_picpathmin = require('gulp-p_w_picpathmin');gulp.src('./img/*.{jpg,png,gif,ico}') .pipe(p_w_picpathmin()) .pipe(gulp.dest('./dist/img'))gulp-zip
描述:ZIP压缩文件。
var zip = require('gulp-zip');gulp.src('./src/*') .pipe(zip('all.zip')) // 压缩成all.zip文件 .pipe(gulp.dest('./dist'))JS/CSS自动注入
gulp-autoprefixer
描述:自动为css添加浏览器前缀。
var autoprefixer = require('gulp-autoprefixer');gulp.src('./css/*.css') .pipe(autoprefixer()) // 直接添加前缀 .pipe(gulp.dest('dist'))gulp.src('./css/*.css') .pipe(autoprefixer({ browsers: ['last 2 versions'], // 浏览器版本 cascade:true // 美化属性,默认true add: true // 是否添加前缀,默认true remove: true // 删除过时前缀,默认true flexbox: true // 为flexbox属性添加前缀,默认true })) .pipe(gulp.dest('./dist'))查看更多配置:options
更多浏览器版本:browsers
gulp-useref
描述:解析构建块在HTML文件来代替引用未经优化的脚本和样式表。
// index.html// gulpfile.jsvar useref = require('gulp-useref');gulp.src('index.html') .pipe(useref()) .pipe(gulp.dest('./dist'))替换之后的index.html中就会变成:
// 之前的两个替换成一个了
gulp-rev
描述:给静态资源文件名添加hash值:unicorn.css => unicorn-d41d8cd98f.css
var rev = require('gulp-rev');gulp.src('./css/*.css') .pipe(rev()) .pipe(gulp.dest('./dist/css'))gulp-rev-replace
描述:重写被gulp-rev重命名的文件名。
var rev = require('gulp-rev');var revReplace = require('gulp-rev-replace');var useref = require('gulp-useref');gulp.src('index.html') .pipe(useref()) // 替换HTML中引用的css和js .pipe(rev()) // 给css,js,html加上hash版本号 .pipe(revReplace()) // 把引用的css和js替换成有版本号的名字 .pipe(gulp.dest('./dist'))gulp-html-replace
描述:替换html中的构建块。
// index.html // css是buildName,可以自己定义// gulpfile.jsvar htmlreplace = require('gulp-html-replace');gulp.src('index.html') .pipe(htmlreplace({ 'css':'all.css' // css是index.html中定义的buildName })) .pipe(gulp.dest('./dist'))替换之后的index.html中就会变成:
// 之前的两个替换成一个了
流控制
gulp-if
描述:有条件地运行一个任务。
var gulpif = require('gulp-if');var uglify = require('gulp-uglify');var concat = require('gulp-concat');var condition = true; gulp.src('./js/*.js') .pipe(gulpif(condition, uglify(), concat('all.js'))) // condition为true时执行uglify(), else 执行concat('all.js') .pipe(gulp.dest('./dist/'));工具
gulp-load-plugins
描述:从包的依赖和附件里加载gulp插件到一个对象里给你选择。
// package.json "devDependencies": { "gulp": "^3.9.1", "gulp-concat": "^2.6.1", "gulp-rename": "^1.2.2", "gulp-uglify": "^2.0.1"}// gulpfile.jsvar $ = require('gulp-load-plugins')(); // $ 是一个对象,加载了依赖里的插件gulp.src('./**/*.js') .pipe($.concat('all.js')) // 使用插件就可以用$.PluginsName() .pipe($.uglify()) .pipe($.rename('all.min.js')) .pipe(gulp.dest('./dist'))gulp-sass
描述:编译sass。
var sass = require('gulp-sass');gulp.src('./sass/**/*.scss') .pipe(sass({ outputStyle: 'compressed' // 配置输出方式,默认为nested })) .pipe(gulp.dest('./dist/css')); gulp.watch('./sass/**/*.scss', ['sass']); // 实时监听sass文件变动,执行sass任务gulp-babel
描述:将ES6代码编译成ES5。
var babel = require('gulp-babel');gulp.src('./js/index.js') .pipe(babel({ presets: ['es2015'] })) .pipe(gulp.dest('./dist'))
文件
前缀
文件名
文件夹
版本
插件
浏览器
浏览
两个
任务
对象
属性
更多
路径
编译
配置
过时
代码
变量
名字
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
做网络安全工程怎么样
赣州唐会网络技术公司
软件开发和版本发布
深圳耀星网络技术有限公司电话
校园网络安全日班会
基岩版服务器起床战争
网络安全小卫士简单手抄报
odoo网站数据库的备份
环境保护数据库的设计与开发
dm数据库指定字符集
2021网络安全宣传周活动通知
网络安全博士课题
网络技术和多媒体哪个简单
范德华体积数据库
国网络安全法的立法方针是
四川农业大学图书馆连接数据库
网络安全贷
共享生鲜柜 软件开发
温州政务软件开发多少钱
网络安全漫画插画
数据仓库与数据库的相似
美国网络安全局局长
四川项目软件开发靠谱吗
各类数据库技术比较
桂林至尊网络技术有限公司
网络安全法 软件开发
易来网络技术
软件开发法律咨询
东方财富交易服务器切换
网络技术开学计划书