gulp的API介绍

gulp的API介绍

使用gulp,仅需知道4个API即可
gulp.task(), gulp.src(), gulp.dest(), gulp.watch(),所以很容易就能掌握

1.gulp.src()

这个方法来读取你需要操作的文件,其语法为

gulp.src(globs[, options])

Gulp内部使用了node-glob模块来实现其文件匹配功能。我们可以使用下面这些特殊的字符来匹配我们想要的文件

* 匹配文件路径中的0个或多个字符,但不会匹配路径分隔符,除非路径分隔符出现在末尾
** 匹配路径中的0个或多个目录及其子目录,需要单独出现,即它左右不能有其他东西了。如果出现在末尾,也能匹配文件。
? 匹配文件路径中的一个字符(不会匹配路径分隔符)
[...] 匹配方括号中出现的字符中的任意一个,当方括号中第一个字符为^或!时,则表示不匹配方括号中出现的其他字符中的任意一个,类似js正则表达式中的用法
!(pattern|pattern|pattern) 匹配任何与括号中给定的任一模式都不匹配的
?(pattern|pattern|pattern) 匹配括号中给定的任一模式0次或1次,类似于js正则中的(pattern|pattern|pattern)?
+(pattern|pattern|pattern) 匹配括号中给定的任一模式至少1次,类似于js正则中的(pattern|pattern|pattern)+
*(pattern|pattern|pattern) 匹配括号中给定的任一模式0次或多次,类似于js正则中的(pattern|pattern|pattern)*
@(pattern|pattern|pattern) 匹配括号中给定的任一模式1次,类似于js正则中的(pattern|pattern|pattern)

下面以一系列例子来加深理解

* 能匹配 a.js,x.y,abc,abc/,但不能匹配a/b.js
*.* 能匹配 a.js,style.css,a.b,x.y
*/*/*.js 能匹配 a/b/c.js,x/y/z.js,不能匹配a/b.js,a/b/c/d.js
** 能匹配 abc,a/b.js,a/b/c.js,x/y/z,x/y/z/a.b,能用来匹配所有的目录和文件
**/*.js 能匹配 foo.js,a/foo.js,a/b/foo.js,a/b/c/foo.js
a/**/z 能匹配 a/z,a/b/z,a/b/c/z,a/d/g/h/j/k/z
a/**b/z 能匹配 a/b/z,a/sb/z,但不能匹配a/x/sb/z,因为只有单**单独出现才能匹配多级目录
?.js 能匹配 a.js,b.js,c.js
a?? 能匹配 a.b,abc,但不能匹配ab/,因为它不会匹配路径分隔符
[xyz].js 只能匹配 x.js,y.js,z.js,不会匹配xy.js,xyz.js等,整个中括号只代表一个字符
[^xyz].js 能匹配 a.js,b.js,c.js等,不能匹配x.js,y.js,z.js

//使用数组的方式来匹配多种文件
gulp.src(['js/*.js','css/*.css','*.html'])
gulp.src([*.js,'!b*.js']) //匹配所有js文件,但排除掉以b开头的js文件
gulp.src(['!b*.js',*.js]) //不会排除任何文件,因为排除模式不能出现在数组的第一个元素中

此外,还可以使用展开模式。展开模式以花括号作为定界符,根据它里面的内容,会展开为多个模式,最后匹配的结果为所有展开的模式相加起来得到的结果。展开的例子如下:

a{b,c}d 会展开为 abd,acd
a{b,}c 会展开为 abc,ac
a{0..3}d 会展开为 a0d,a1d,a2d,a3d
a{b,c{d,e}f}g 会展开为 abg,acdfg,acefg
a{b,c}d{e,f}g 会展开为 abdeg,acdeg,abdeg,abdfg

2.gulp.dest()

2.1 gulp.dest()方法是用来写文件的,其语法为:gulp.dest(path[,options])
2.2 通过一些例子来说明

gulp.src('script/avalon/avalon.js') 
     //没有通配符出现的情况
    .pipe(gulp.dest('dist'));
    //最后生成的文件路径为 dist/avalon.js
    //有通配符开始出现的那部分路径为 **/underscore.js

gulp.src('script/**/underscore.js')
     //假设匹配到的文件为script/util/underscore.js
     .pipe(gulp.dest('dist')); 
     //则最后生成的文件路径为dist/util/underscore.js

gulp.src('script/*') 
     //有通配符出现的那部分路径为 *
     //假设匹配到的文件为script/zepto.js    
     .pipe(gulp.dest('dist')); 
     //则最后生成的文件路径为 dist/zepto.js

gulp.src('app/src/**/*.css')
     //此时base的值为app/src,也就是说它的base路径为app/src
     //设该模式匹配到了文件 app/src/css/normal.css
     .pipe(gulp.dest('dist')) 
     //用dist替换掉base路径,最终得到 dist/css/normal.css

gulp.src(script/lib/*.js) 
     //没有配置base参数,此时默认的base路径为script/lib
     //假设匹配到的文件为script/lib/jquery.js
     .pipe(gulp.dest('build')) 
     //生成的文件路径为 build/jquery.js

gulp.src(script/lib/*.js, {base:'script'}) 
     //配置了base参数,此时base路径为script
     //假设匹配到的文件为script/lib/jquery.js
     .pipe(gulp.dest('build')) 
     //此时生成的文件路径为 build/lib/jquery.js 

3.gulp.task()

3.1 gulp.task方法用来定义任务,内部使用的是Orchestrator,其语法为:

gulp.task(name[, deps], fn)
name 为任务名
deps 是当前定义的任务需要依赖的其他任务,为一个数组。当前定义的任务会在所有依赖的任务执行完毕后才开始执行。如果没有依赖,则可省略这个参数
fn 为任务函数,我们把任务要执行的代码都写在里面。该参数也是可选的。
gulp.task('mytask', ['array', 'of', 'task', 'names'], function() { //定义一个有依赖的任务
      // Do something
    });

4.gulp.watch()

gulp.watch()用来监视文件的变化,当文件发生变化后,我们可以利用它来执行相应的任务,例如文件压缩等。其语法为

gulp.watch(glob[, opts], tasks)
glob 为要监视的文件匹配模式,规则和用法与gulp.src()方法中的glob相同。
opts 为一个可选的配置对象,通常不需要用到
tasks 为文件变化后要执行的任务,为一个数组
gulp.task('uglify',function(){
      //do something
    });
    gulp.task('reload',function(){
      //do something
    });
    gulp.watch('js/**/*.js', ['uglify','reload']);

gulp.watch()还有另外一种使用方式:

gulp.watch(glob[, opts, cb])

glob和opts参数与第一种用法相同

cb参数为一个函数。每当监视的文件发生变化时,就会调用这个函数,并且会给它传入一个对象,该对象包含了文件变化的一些信息,type属性为变化的类型,可以是added,changed,deleted;path属性为发生变化的文件的路径
gulp.watch('js/**/*.js', function(event){
        console.log(event.type); //变化类型 added为新增,deleted为删除,changed为改变 
        console.log(event.path); //变化的文件的路径
    });
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Webpack,Vite,Rollup和Gulp都是常见的前端构建工具,用于帮助开发者在项目中管理、打包和优化代码。 Webpack是目前最流行的构建工具之一,它可以将多个模块和资源打包成一个或多个bundle文件。它具有强大的插件系统和丰富的生态系统,可以满足各种开发需求。Webpack的配置复杂,但功能强大,适合复杂的大型项目。 Vite是一个新兴的构建工具,主要用于快速开发单页面应用(SPA)。它通过基于浏览器原生模块系统(ES模块)的优化策略来提供即时的热重载,几乎可以实时重新建立和重新加载应用程序。Vite通过只在开发时进行转换和构建来提供快速的开发体验,大大提高了开发效率。 Rollup是另一个逐渐流行的构建工具,专注于构建JavaScript库和组件。与Webpack和Vite不同,Rollup更注重生成适合编写和使用库的文件,生成更小、更高效的代码。Rollup支持Tree-Shaking等高级优化技术,帮助开发者生成更优化的代码。 Gulp是一个基于流的构建工具,具有简洁的API和易于使用的方式。Gulp主要用于自动化任务,可以帮助开发者在开发过程中处理和转换文件,例如压缩、合并、混淆等。Gulp有丰富的插件和强大的任务处理能力,可以轻松地构建各种前端工作流。 综上所述,Webpack适用于大型项目的复杂构建需求,Vite适用于快速开发SPA,Rollup适用于构建JavaScript库和组件,而Gulp适用于自动化任务。根据项目的具体需求和规模,开发者可以选择适合的构建工具来提高开发效率和优化代码质量。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值