执行gulp 任务

gulp taskname (default任务不输入名称亦可:gulp)

var gulp = require("gulp");
gulp.task("a",function(){
console.log("aaa");
});

gulp 前置任务

gulp.task(当前任务,["前置任务"],回调函数)

var gulp = require("gulp");
gulp.task("a",function(){
console.log("aaa");
});
gulp.task("aftera",["a"],function(){
console.log("after a");
});

gulp src pipe dest 读写文件

  • src:读取,gulp.src(globs),globs是筛选条件,可以是字符串和数组,[patha,pathb...]:读取多个文件
  • pipe:管道,a.pipe(b):将a写入到b中
  • dest:写入,gulp.dest(path):将文件写入到指定路径

gulp.src(globs).pipe(gulp.dest(path)):读取文件并写入到指定路径

示例:读取src目录下下的所有js文件,写入到dist目录下

var gulp = require("gulp");
gulp.task("dofile", function () {
gulp.src("./src/**/*.js")
.pipe(gulp.dest("./dist"));
});

gulp watch 监控

watch方法用于监视文件变化

gulp.watch(url,fn(event){}),
gulp.watch([url1,url2...],fn(event){})

gulp.task("watchfile",function(){
gulp.watch('./src/js/test.js',function(event){
console.log(event.type);//added deleted changed
console.log(event.path);
});
});

gulp插件:

gulp uglify 压缩文件插件

ugligy:压缩文件,可以将文件中的空格删除

下载插件:npm i gulp-uglify --save -dev

var gulp = require("gulp");
var uglify = require("gulp-uglify");
gulp.task("douglify",function(){
gulp.src("./src/js/a.js")
.pipe(uglify())
.pipe(gulp.dest('./uglify'));
});

压缩前与压缩后效果:

gulp rename 重命名

下载插件:npm i gulp-rename --save -dev

gulp.rename(string)

读取文件,压缩并重命名写入另一个目录:

var gulp = require("gulp");
var uglify = require("gulp-uglify");
var rename = require("gulp-rename");
gulp.task("renamefile",function(){
gulp.src("./src/js/test.js")
.pipe(uglify())
.pipe(rename("updateName.js"))
.pipe(gulp.dest("./rename"));
});

gulp-minify-css 压缩css文件

下载插件:npm i gulp-minify-css --save -dev

将css文件压缩,可不写参数,在管道流中操作

var gulp = require("gulp");
var cssminify = require("gulp-minify-css");
gulp.task("minicss", function () {
gulp.src("./src/css/*.css")
.pipe(cssminify())
.pipe(gulp.dest("./src/css/mini"));
})

gulp-minify-html 压缩html文件

下载插件:npm i gulp-minify-html --save -dev

在管道流中操作

var gulp = require("gulp");
var HTMLminify = require("gulp-minify-html");
gulp.task("htmlminify",function(){
gulp.src("./src/html/*.*")
.pipe(HTMLminify())
.pipe(gulp.dest("./src/html/minify"));
});

gulp-concat 合并文件

下载插件:npm i gulp-concat --save -dev

concat(filename)

var gulp = require("gulp");
var concat = require("gulp-concat");
gulp.task("concatfile",()=>{
gulp.src("./src/js/*.js")
.pipe(concat('all.js'))
.pipe(gulp.dest('./src/js/concat'));
});

gulp-sass 解析sass

下载插件:npm i gulp-sass --save -dev

sass():在管道流中操作,将sass解析成css

var gulp = require("gulp");
var sass = require("gulp-sass");
gulp.task("sassfile",()=>{
gulp.src("./src/sass/c.scss")
.pipe(sass())
.pipe(gulp.dest("./src/sass"));
});

gulp-imagemin 压缩图片

下载插件:npm i gulp-imagemin --save -dev

var gulp = require("gulp");
var imagemin = require("gulp-imagemin");
gulp.task("imgmin",()=>{
gulp.src("./src/images/*.*")
.pipe(imagemin())
.pipe(gulp.dest('./src/images/min'));
});

自动加载插件:

  • npm install --save-dev gulp-load-plugins

gulp 常用方法 任务 插件的更多相关文章

  1. 前端构建之gulp与常用插件

    gulp是什么? http://gulpjs.com/ 相信你会明白的! 与著名的构建工具grunt相比,有什么优势呢? 易于使用,代码优于配置 高效,不会产生过多的中间文件,减少I/O压力 易于学习 ...

  2. gulp自动刷新插件

    gulp自动刷新的插件很多,但是感觉最好用的还是 browser-sync 插件.如果不想用命令行,也可以使用 browser-sync界面工具 先安装 browser-sync 插件: npm in ...

  3. gulp如何自定义插件

    gulp是基于”流“的构建工具,上层流的输出就是下层流的输入,为了更好的支持链式操作,可以使用through2或者map-stream这两个库来对node stream做一层包装 这里,我们就使用th ...

  4. 前端构建之gulp与常用插件(转载)

    原博主:幻天芒 原文地址:http://www.cnblogs.com/humin/p/4337442.html gulp是什么? http://gulpjs.com/ 相信你会明白的! 与著名的构建 ...

  5. 前端自动化Gulp工具常用插件

    npm init命令初始化当前文件夹后,在当前文件夹新建gulpfile.js文件.当前目录下的所有操作流都在gulpfile.js文件中定义. gulp自动化 gulp-uglify (JS压缩) ...

  6. Gulp工具常用插件

    gulp-uglify(js压缩) gulp-uglify安装 // npm install --save-dev gulp-uglify 已过时 npm install --save-dev jsh ...

  7. gulp的常用插件

    gulp和webpack的差别:https://www.cnblogs.com/lovesong/p/6413546.html var gulp = require('gulp'); var del ...

  8. gulp常用的插件

    参考地址: http://www.cnblogs.com/1wen/p/5421212.html https://my.oschina.net/wolfx/blog/673905 http://www ...

  9. gulp常用方法

    var gulp = require('gulp'); var concat = require('gulp-concat'); //使用gulp-concat合并文件,减少网络请求(静态资源数量): ...

随机推荐

  1. [CF3B] Lorry - 贪心

    有一辆载重量为 v 的货车, 准备运送两种物品. 物品 A 的重量为 1, 物体 B 的重量为 2, 每个物品都有一个价值. 求货车可以运送的物品的最大价值. Solution 考虑把物品分为两类,枚 ...

  2. BK: Data mining: concepts and techniques (1)

    Chapter 1 data mining is knowledge discovery from data; The knowledge discovery process is an iterat ...

  3. gogs迁移至gitlab

    一.先来聊一聊迁移的思路,不管是gogs迁移至gitlab,还是gitlab迁移至gogs,亦或gitlab迁移至gitlab,手动迁移的步骤都是如下图所示(在gitlab上新建一个空项目就会有这样的 ...

  4. 《JavaScript ES6 函数式编程入门经典》--推荐指数⭐⭐⭐

    这本书比较基础认真看完再自己写点demo一个双休日就差不多, 总体来说看完还是有收获的,会激起一些你对函数编程的兴趣 主要目录如下: 第1章 函数式编程简介 11.1 什么是函数式编程?为何它重要 1 ...

  5. python3练习100题——029

    原题链接:http://www.runoob.com/python/python-exercise-example29.html 题目:给一个不多于5位的正整数,要求:一.求它是几位数,二.逆序打印出 ...

  6. python threading2种调用方式实例

    1.认识GIL: 说到GIL一直是代码专家们一直以来想要解决的问题,也是被许多程序员诟病的,下面带领大家看下官方threading模块document中如何去描述对于GIL这个全局解释器锁的:http ...

  7. 数据从mmsql导入mysql

    SQL SERVER数据导入MYSQL 工具: navicat for mysql 百度搜一个安装就可以,前提是你已经安装了mysql 1,创建目标数据库 点击创建好的目标数据库website点的表一 ...

  8. pikaqiu练习平台(SQL注入 )

    sql注入漏洞 (危害是最大得) Sql注入 数据库注入漏洞,主要是开发人员在构建代码时,没有对输入边界进行安全考虑,导致攻击者可以通过合法的输入点提交一些精心构造的语句,从而欺骗后台数据库对其进行执 ...

  9. 【PAT甲级】1117 Eddington Number (25分)

    题意: 输入一个正整数N(<=100000),接着输入N个非负整数.输出最大的整数E使得有至少E个整数大于E. AAAAAccepted code: #define HAVE_STRUCT_TI ...

  10. nginx下载,安装,基础命令,和代理tomcat例子理解

    nginx代理讲的很好理解:https://www.cnblogs.com/ysocean/p/9392908.html 一.nginx应用场景: 1.反向代理(用的非常多) 客户端发出请求,反向代理 ...