gulp 常用方法 任务 插件
执行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 常用方法 任务 插件的更多相关文章
- 前端构建之gulp与常用插件
gulp是什么? http://gulpjs.com/ 相信你会明白的! 与著名的构建工具grunt相比,有什么优势呢? 易于使用,代码优于配置 高效,不会产生过多的中间文件,减少I/O压力 易于学习 ...
- gulp自动刷新插件
gulp自动刷新的插件很多,但是感觉最好用的还是 browser-sync 插件.如果不想用命令行,也可以使用 browser-sync界面工具 先安装 browser-sync 插件: npm in ...
- gulp如何自定义插件
gulp是基于”流“的构建工具,上层流的输出就是下层流的输入,为了更好的支持链式操作,可以使用through2或者map-stream这两个库来对node stream做一层包装 这里,我们就使用th ...
- 前端构建之gulp与常用插件(转载)
原博主:幻天芒 原文地址:http://www.cnblogs.com/humin/p/4337442.html gulp是什么? http://gulpjs.com/ 相信你会明白的! 与著名的构建 ...
- 前端自动化Gulp工具常用插件
npm init命令初始化当前文件夹后,在当前文件夹新建gulpfile.js文件.当前目录下的所有操作流都在gulpfile.js文件中定义. gulp自动化 gulp-uglify (JS压缩) ...
- Gulp工具常用插件
gulp-uglify(js压缩) gulp-uglify安装 // npm install --save-dev gulp-uglify 已过时 npm install --save-dev jsh ...
- gulp的常用插件
gulp和webpack的差别:https://www.cnblogs.com/lovesong/p/6413546.html var gulp = require('gulp'); var del ...
- gulp常用的插件
参考地址: http://www.cnblogs.com/1wen/p/5421212.html https://my.oschina.net/wolfx/blog/673905 http://www ...
- gulp常用方法
var gulp = require('gulp'); var concat = require('gulp-concat'); //使用gulp-concat合并文件,减少网络请求(静态资源数量): ...
随机推荐
- 常见通用框架的理解(Redis,Zookeeper,Thrift)
redis 主要功能是内存版的Hashta zookeeper 主要功能是分布式中的全局变量. thrift 跨平台的Client和Server通信架构. taskengine用于启动定时任务和查看 ...
- django学习,captcha图形验证码的使用
很多网站在登录或者注册的时候都有验证码,让你去输入. 刚好有这么一款插件,可以满足这个功能 首先,先pip install django-simple-captcha 然后再setting里添加,如 ...
- Python读取Excel,日期列读出来是数字的处理
Python读取Excel,里面如果是日期,直接读出来是float类型,无法直接使用. 通过判断读取表格的数据类型ctype,进一步处理. 返回的单元格内容的类型有5种: ctype: 0 empty ...
- idea 配置 tomcat 教程
最近在搞一个项目需要用到idea 配置tomcat,翻了翻网上的帖子发现稂莠不齐,最后决定还是自己写个吧!(其实我挺蠢的走了好多的弯路,哎~) 1.首先准备一个需要大家tomcat的工程,然后使用id ...
- JUC-JUC是什么?
一.JUC是什么? java.util.concurrent在并发编程中使用的工具类 进程/线程回顾 1.进程/线程是什么? 进程:进程是一个具有一定独立功能的程序关于某个数据集合的一次运行活动.它是 ...
- mybatis(四):执行流程
实现流程 // 读取mybatis-config.xml文件 InputStream inputStream = Resources.getResourceAsStream("mybatis ...
- day18 sed
具体功能作用: 1) 文件中添加信息的能力 (增) ok 2) 文件中删除信息的能力 (删) ok 3) 文件中修改信息的能力 (改) 4) 文件中查询信息的能力 (查) OK sed命令的语法信息 ...
- [CF1236D] Alice and the Doll - 模拟,STL
[CF1236D] Alice and the Doll Description \(N \times M\)网格,有 \(K\) 个格子里有障碍物.每次经过一个格子的时候只能直走或者右转一次.初态在 ...
- Oracle tnsnames.ora
安装过ORACLE的都知道,oracle安装时需要进行配置,这个配置可以在客户端的企业管理器一步一步进行,或者直接拷贝一个tnsnames.ora文件到安装目录下(c:\app\Administrat ...
- Visual detection of structural changes in time-varying graphs using persistent homology
PKU blog about this paper Basic knowledge: 1. what is time-varying graphs? time-varying graph VS st ...