博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
前端构建大法 Gulp 系列 (三):gulp的4个API 让你成为gulp专家
阅读量:5954 次
发布时间:2019-06-19

本文共 1546 字,大约阅读时间需要 5 分钟。

系列目录

gulp 本身能做的事情非常少,主要是通过插件来提供各种功能,gulp本身只提供了4个非常简洁的API, 掌握这4个API你就基本掌握了gulp的全部。

一、gulp.task

gulp 是基于task的方式来运行

定义

gulp.task(name [, deps, fn])

注册一个task, name 是task的名字,deps是可选项,就是这个task依赖的tasks, fn是task要执行的函数

示例

gulp.task('js', ,['jscs', 'jshint'], function(){ return gulp    .src('./src/**/*.js')    .pipe(concat('alljs'))    .pipe(uglify())    .pipe(gulp.dest('./build/'));                 });

提示

上例中

  • jscs和jshint先运行,随后再运行js的task.
  • jscs和jshint是并行执行的,而不是顺序执行

二、gulp.src

定义

gulp.src(globs[, options])

与globs 匹配的文件,可以是string或者一个数组

示例

gulp.src(['client/*.js', '!client/b*.js', 'client/c.js'])   # !是排除某些文件gulp.task('js',['jscs', 'jshint'],function(){ return gulp    .src('./src/**/*.js', {base:'./src/'})            .pipe(uglify())    .pipe(gulp.dest('./build/'));             });

options.base 是指多少路径被保留,比如上面的 ./src/users/list.js 会被输出到 ./build/users/list.js

提示

如果我们需要文件保持顺序,那么出现在前面的文件就写在数组的前面

gulp.src(['client/baby.js', 'client/b*.js', 'client/c.js'])

上面baby.js就出现在最上面。

三、 gulp.dest

定义

gulp.dest(path[, options]) 就是最终文件要输出的路径,options一般不用

四、gulp.watch

定义

gulp.watch(glob [, opts], tasks) or gulp.watch(glob [, opts, cb]) 就是监视文件的变化,然后运行指定的Tasks或者函数,这个相比Grunt需要使用插件,gulp本身就支持的很好。

示例

gulp.task('watch-js', function(){   gulp.watch('./src/**/*.js',['jshint','jscs']); });gulp.task('watch-less', function(){ gulp.watch('./src/**/*.less',function(event){   console.log('less event'+event.type+' '+event.path) }); });

最后

gulp就是如此的简单,你只需要掌握这四个API就够了,剩下的就是熟悉相关的plugin了。

参考链接 

本文转自敏捷的水博客园博客,原文链接http://www.cnblogs.com/cnblogsfans/p/5101138.html如需转载请自行联系原作者

王德水

你可能感兴趣的文章
Android开发学习总结(五)——Android应用目录结构分析(转)
查看>>
观察者模式
查看>>
[PHP]PHP rpc框架hprose测试
查看>>
Atom 编辑器系列视频课程
查看>>
C#三种定时器
查看>>
范数 L1 L2
查看>>
协同过滤及大数据处理
查看>>
Java8 本地DateTime API
查看>>
jQuery 增加 删除 修改select option
查看>>
[原][osgearth]osgearthviewer读取earth文件,代码解析(earth文件读取的一帧)
查看>>
springboot 常用插件
查看>>
一个基于特征向量的近似网页去重算法——term用SVM人工提取训练,基于term的特征向量,倒排索引查询相似文档,同时利用cos计算相似度...
查看>>
[转]Newtonsoft.Json高级用法
查看>>
35个Java代码性能优化总结
查看>>
Spring+SpringMVC+MyBatis+easyUI整合基础篇(一)项目简述及技术选型介绍
查看>>
剑指offer——35复杂链表的复制
查看>>
DFI、DPI技术
查看>>
hibernate 执行存储过程 方法
查看>>
RapidIOIP核的验证方法研究_王玉欢
查看>>
崩溃日志的实例
查看>>