简介gulp是前端自动化打包构建工具,所谓打包可以理解为把文件压缩, 整合, 移动, 混淆。gulp是一种基于流的打包构建工具。
文档:https://www.gulpjs.com.cn/docs/api/concepts/
使用gulp,首先要全局安装gulp
,全局安装只是可以使用其命令
1 2 3 4 5 6 npm install --global gulp npm uninstall --global gulp gulp -v
也可以局部安装,通过scripts
运行。
常用APItask()
创建一个基于流的任务
1 2 3 gulp.task('htmlHandler' , function ( ) { })
src()
找到源文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 gulp.src('./a/b.html' ) gulp.src('./a/*.html' ) gulp.src('./a/**' ) gulp.src('./a/** /*' ) gulp.src('./a/** /*.html' )
dest()
把一个内容放入指定目录内
watch()
监控指定目录下的文件, 一旦发生变化, 从新执行后面的任务
1 gulp.watch('./src/pages/*.html' , htmlHandler)
series()
逐个执行多个任务, 前一个任务结束, 第二个任务开始
1 gulp.series(任务1 , 任务2 , 任务3 , ...)
parallel()
并行开始多个任务
1 gulp.parallel(任务1 , 任务2 , 任务3 , ...)
pipe()
管道函数,所有的 gulp API 都是基于流。接收当前流, 进入下一个流过程的管道函数
1 gulp.src().pipe(压缩任务).pipe(转码).pipe(gulp.dest('abc' ))
常用插件gulp-cssmin
导入以后得到一个处理流文件的函数
https://www.npmjs.com/package/gulp-cssmin
gulp-autoprefixer
1 npm i gulp-autoprefixer -D
导入以后得到一个处理流文件的函数,直接再管道函数里面使用, 需要传递参数
https://www.npmjs.com/package/gulp-autoprefixer
gulp-sass
编译scss
和sass
文件为css
文件
导入后直接使用即可
gulp-less
与gulp-sass
类似,编译less
文件为css
文件
gulp-uglify
压缩js
文件
此压缩不可以压缩ES6
,因此如果有ES6代码,需要先转为ES5
gulp-babel
专门进行 ES6 转 ES5 的插件。
1 yarn add gulp-babel @babel/core @babel/preset-env -D
gulp-babel有两个版本,8主要用于gulp4中,7主要用于gulp3中。默认安装最新版。
gulp-htmlmin
压缩html
del
删除文件目录
gulp-connect
启动一个服务器,用于自动构建。
1 yarn add gulp-connect -D
gulp-pug
编译pug
为html
文件
gulp-concat
合并js/css
文件
常用示例 构建JS将含有ES6代码的js文件合并并压缩。
安装插件
1 yarn add gulp-concat gulp-uglify gulp-rename gulp-babel @babel/core @babel/preset-env -D
编写构建任务
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 var gulp = require ('gulp' )var concat = require ('gulp-concat' )var uglify = require ('gulp-uglify' )var rename = require ('gulp-rename' )var babel = require ('gulp-babel' )const js = () => { return ( gulp .src('src/js/*.js' ) .pipe( babel({ presets: ['@babel/env' ] }) ) .pipe(uglify()) .pipe(gulp.dest('dist/js/' )) ) } exports .default = gulp.parallel(js)
css、less、scss、sass安装插件
1 yarn add gulp-less gulp-sass gulp-clean-css gulp-concat del gulp-rename -D
编写任务代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 const scssTask = () => { return gulp .src('./src/scss/*.scss' ) .pipe(sass()) .pipe(gulp.dest('./src/css/scss/' )) } const lessTask = () => { return gulp .src('./src/less/*.less' ) .pipe(less()) .pipe(gulp.dest('./src/css/less/' )) } const delLessScss = () => { return del(['./src/css/less/' , './src/css/scss/' ]) } const cssTask = async () => { return gulp .src('./src/css/**/*.css' ) .pipe(concat('build.css' )) .pipe(rename({ suffix : '.min' })) .pipe(cssClean({ compatibility : 'ie8' })) .pipe(gulp.dest('dist/css/' )) } exports .default = gulp.series( gulp.parallel(scssTask, lessTask), cssTask, delLessScss )
编译pug、压缩html安装插件
1 yarn add gulp-htmlmin gulp-pug del -D
编写压缩任务
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 const delDest = () => { return del(['./dist/' ]) } const pugTask = () => { return gulp.src('./src/pug/*.pug' ).pipe(pug()).pipe(gulp.dest('./dist/' )) } const htmlminTask = () => { return gulp.src('./dist/**/*.html' ).pipe( htmlmin({ removeComments: true , collapseWhitespace: true , collapseBooleanAttributes: true , removeEmptyAttributes: true , removeScriptTypeAttributes: true , removeStyleLinkTypeAttributes: true , minifyJS: true , minifyCSS: true }) ) } exports .default = gulp.series(delDest, pugTask, htmlminTask)
自动化示例1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 var gulp = require ('gulp' )var pug = require ('gulp-pug' )var htmlmin = require ('gulp-htmlmin' )var less = require ('gulp-less' )var sass = require ('gulp-sass' )var cssClean = require ('gulp-clean-css' )var uglify = require ('gulp-uglify' )var babel = require ('gulp-babel' )var concat = require ('gulp-concat' )var rename = require ('gulp-rename' )var del = require ('del' )var connect = require ('gulp-connect' )var open = require ('open' )const delDest = () => { return del(['./dist/' ]) } const delLessScss = () => { return del(['./src/css/less/' , './src/css/scss/' ]) } const pugTask = () => { return gulp .src('./src/pug/*.pug' ) .pipe(pug()) .pipe(gulp.dest('./dist/' )) .pipe(connect.reload()) } const htmlminTask = () => { return gulp .src('./dist/**/*.html' ) .pipe( htmlmin({ removeComments: true , collapseWhitespace: true , collapseBooleanAttributes: true , removeEmptyAttributes: true , removeScriptTypeAttributes: true , removeStyleLinkTypeAttributes: true , minifyJS: true , minifyCSS: true }) ) .pipe(connect.reload()) } const scssTask = () => { return gulp .src('./src/scss/*.scss' ) .pipe(sass()) .pipe(gulp.dest('./src/css/scss/' )) .pipe(connect.reload()) } const lessTask = () => { return gulp .src('./src/less/*.less' ) .pipe(less()) .pipe(gulp.dest('./src/css/less/' )) .pipe(connect.reload()) } const cssTask = async () => { return gulp .src('./src/css/**/*.css' ) .pipe(concat('build.css' )) .pipe(rename({ suffix : '.min' })) .pipe(cssClean({ compatibility : 'ie8' })) .pipe(gulp.dest('dist/css/' )) .pipe(connect.reload()) } const jsTask = () => { return gulp .src('src/js/*.js' ) .pipe( babel({ presets: ['@babel/env' ] }) ) .pipe(uglify()) .pipe(gulp.dest('dist/js/' )) .pipe(connect.reload()) } const server = () => { gulp.watch(['src/scss/**/*.scss' ], gulp.series(scssTask)) gulp.watch(['src/less/**/*.less' ], gulp.series(lessTask)) gulp.watch(['src/css/**/*.css' ], gulp.series(cssTask)) gulp.watch(['src/pug/**/*.pug' ], gulp.series(pugTask)) gulp.watch(['src/js/**/*.js' ], gulp.series(jsTask)) connect.server({ root: 'dist/' , livereload: true , port: 5000 }) open('http://localhost:5000/' ) } gulp.task( 'build' , gulp.series( delDest, pugTask, htmlminTask, scssTask, lessTask, cssTask, jsTask, delLessScss ) ) gulp.task('server' , gulp.series('build' , server))
关于任务执行顺序同步执行即按顺序执行
1 exports .default = gulp.series('js' ,['less' , 'css' ])
异步执行即不会按照顺序去执行
1 exports .default = gulp.parallel('js' ,['less' , 'css' ])
这两个方法支持任意层次的嵌套。
1 exports .default = gulp.parallel('js' , gulp.series(['less' , 'css' ]))