gulp的点点滴滴
去年用gulp,但一直没有写篇博客,今天有时间无聊写一篇。。。。
什么是gulp?gulp的官网title上对这个工具有一个比较准确的定义,叫做:基于流的自动化构建工具。如果你查看它的网页源代码,还会看到在<meta>标签里有一段更详细的描述:gulp.js 是一个自动化构建工具,开发者可以使用它在项目开发过程中自动执行常见任务。gulp.js 是基于 Node.js 构建的,利用 Node.js 流的威力,你可以快速构建项目并减少频繁的 IO 操作。gulp.js 源文件和你用来定义任务的 gulp 文件都是通过 JavaScript(或者 CoffeeScript )源码来实现的。
好了废话不多说,直接上代码,下面是我写的gulpfile,里面的一些模块不懂的可以去 => https://www.npmjs.com/ 搜索看使用方法,俗话说看源码是最快的学习途径。。。
'use strict';
{
let gulp = require(`gulp`);
let path = require(`./config.json`);
let minifycss = require(`gulp-minify-css`);
let postcss = require(`gulp-postcss`);
let cssgrace = require(`cssgrace`);
let cssnext = require(`postcss-cssnext`);
let jshint = require(`gulp-jshint`);
let uglify = require(`gulp-uglify`);
let fontmin = require(`gulp-fontmin`);
let imagesmin = require(`gulp-imagemin`);
let pngquant = require(`imagemin-pngquant`);
let through = require(`through2`);
let html = require(`html-minifier`).minify;
let cheerio = require(`cheerio`);
let clean = require(`gulp-clean`);
let rename = require(`gulp-rename`);
let browserSync = require(`browser-sync`);
let reload = browserSync.reload;
let processors = [
cssnext(),
cssgrace
];
gulp.task(`browser-sync`, () => {
return browserSync({
port:8080,
open:true,
server: {
baseDir: `./build`
}
});
});
gulp.task(`css`,() => {
return gulp.src(path.src.css)
.pipe(postcss(processors))
.pipe(rename({suffix: `.min`}))
.pipe(minifycss())
.pipe(gulp.dest(path.build.css))
.pipe(reload({stream: true}));
});
gulp.task(`lint`,() => {
return gulp.src(path.src.js)
.pipe(jshint())
.pipe(jshint.reporter(`default`));
});
gulp.task(`script`,() => {
return gulp.src(path.src.js)
.pipe(uglify())
.pipe(rename({suffix: `.min`}))
.pipe(gulp.dest(path.build.js))
.pipe(reload({stream: true}));
});
gulp.task(`fonts`, (cb) => {
let buffers = [];
gulp.src(path.src.html)
.on(`data`, (file) => {
buffers.push(file.contents);
})
.on(`end`, () => {
let text = Buffer.concat(buffers).toString(`utf-8`);
return minifyFont(text, cb);
});
});
gulp.task(`img`, () => {
return gulp.src(path.src.img)
.pipe(imagesmin({
progressive: true,
use: [pngquant()]
}))
.pipe(gulp.dest(path.build.img))
.pipe(reload({stream: true}));;
});
gulp.task(`html`, () => {
return gulp.src(path.src.html)
.pipe(through.obj( (file, encode,cb) => {
let content = file.contents.toString(encode);
let $ = cheerio.load(content,{decodeEntities:false});
let aLink = $(`link`);
let aScript = $(`script`);
rep($,aLink);
rep($,aScript);
content = $.html();
let miniHtml = html(content,{
minifyCSS:true,
minifyJS:true,
collapseWhitespace:true,
removeAttributeQuotes:true
});
file.contents = new Buffer(miniHtml,encode);
cb(null,file,encode);
}))
.pipe(gulp.dest(path.build.html))
.pipe(reload({stream: true}));
});
gulp.task(`ico`, () => {
return gulp.src(path.src.ico)
.pipe(gulp.dest(path.build.html));
});
gulp.task(`clean`, () => {
return gulp.src([path.build.html], {read: false})
.pipe(clean());
});
gulp.task(`default`,[`clean`], () => {
gulp.start(`browser-sync`, `lint`, `html`, `fonts`, `script`, `img`, `css`, `ico`);
gulp.watch(path.src.html, [`html`]);
gulp.watch(path.src.css, [`css`]);
gulp.watch(path.src.images, [`img`]);
gulp.watch(path.src.js, [`script`]);
gulp.watch(path.src.fonts, [`fonts`]);
});
let rep = ($,hrefs) => {
hrefs.each((index, item) => {
let oLink = $(item);
if(oLink.attr(`rel`) === `stylesheet`){
let href = oLink.attr(`href`).replace(/\.\w+$/g,(str) => {
return `.min${str}`;
});
oLink.attr(`href`,href);
}else if(oLink.attr(`type`) === `text/javascript`){
let href = oLink.attr(`src`).replace(/\.\w+$/g,(str) => {
return `.min${str}`;
});
oLink.attr(`src`,href);
}
});
};
let minifyFont = (text, cb) => {
return gulp.src(path.src.fonts)
.pipe(fontmin({
text: text
}))
.pipe(gulp.dest(path.build.fonts))
.on(`end`, cb);
};
}
gulp一些基础用法可以去 http://www.imooc.com/course/list 看看,很不错的,我给66个赞。。。
gulp的点点滴滴的更多相关文章
- 构建一个基本的前端自动化开发环境 —— 基于 Gulp 的前端集成解决方案(四)
通过前面几节的准备工作,对于 npm / node / gulp 应该已经有了基本的认识,本节主要介绍如何构建一个基本的前端自动化开发环境. 下面将逐步构建一个可以自动编译 sass 文件.压缩 ja ...
- 常用 Gulp 插件汇总 —— 基于 Gulp 的前端集成解决方案(三)
前两篇文章讨论了 Gulp 的安装部署及基本概念,借助于 Gulp 强大的 插件生态 可以完成很多常见的和不常见的任务.本文主要汇总常用的 Gulp 插件及其基本使用,需要读者对 Gulp 有一个基本 ...
- 在windows下安装gulp —— 基于 Gulp 的前端集成解决方案(一)
相关连接导航 在windows下安装gulp —— 基于 Gulp 的前端集成解决方案(一) 执行 $Gulp 时发生了什么 —— 基于 Gulp 的前端集成解决方案(二) 常用 Gulp 插件汇总 ...
- 执行 $Gulp 时发生了什么 —— 基于 Gulp 的前端集成解决方案(二)
前言 文章 在windows下安装gulp —— 基于 Gulp 的前端集成解决方案(一) 中,已经完成对 gulp 的安装,由于是window环境,文中特意提到了可以通过安装 gitbash 来代替 ...
- gulp详细入门教程
本文链接:http://www.ydcss.com/archives/18 gulp详细入门教程 简介: gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器:她不仅能对网站资源进行优 ...
- 做一个gulp+webpack+vue的单页应用开发架子
1.目标 最近项目上的事情不多,根据我自己的开发习惯,决定开发一些简单的开发架子,方便以后事情多的时候直接套用.本文讲的一个gulp+webpack+vue的单页应用架子,想要达到的目的: 可以通过命 ...
- 前端自动化构建工具gulp记录
一.安装 1)安装nodejs 通过nodejs的npm安装gulp,插件也可以通过npm安装.windows系统是个.msi工具,只要一直下一步即可,软件会自动在写入环境变量中,这样就能在cmd命令 ...
- gulp初学
原文地址:gulp初学 至于gulp与grunt的区别,用过的人都略知一二,总的来说就是2点: 1.gulp的gulpfile.js 配置简单而且更容易阅读和维护.之所以如此,是因为它们的工作方式不 ...
- gulp批量打包文件并提取公共文件
gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器. browseriyf是模块化打包工具. 一般情况下,Browserify 会把所有的模块打包成单个文件.单个文件在大多数情况下是 ...
随机推荐
- PLSQL Developer激活码
License Number:999 Password:xs374ca Product Code:ljkfuhjpccxt8xq2re37n97595ldmv9kch Serial Number:30 ...
- 小游戏 Lights Out (关灯) 的求解 —— 异或方程组
Author : Evensgn Blog Link : http://www.cnblogs.com/JoeFan/ Article Link : http://www.cnblogs.com/J ...
- ios7新特性3-Map Kit新特性
Map Kit 框架 (MapKit.framework) 包含了大量的改进以及为基于地图的程序提供了新特性.利用地图显示位置信息的应用现在可以使用Maps这个程序用到的3D地图,包括控制程序控制视线 ...
- Java位运算总结:位运算用途广泛《转》
前天几天研究了下JDK的Collection接口,本来准备接着研究Map接口,可是一查看HashMap类源码傻眼咯,到处是位运算实现,所以我觉得还是有必要先补补位运算知识,不然代码看起来有点费力.今天 ...
- 分布式文件系统FastDFS安装与配置(单机)
安装包如下:fastdfs-nginx-module_v1.16.tar.gzFastDFS_v5.05.tar.gzlibfastcommon-master.zipnginx-1.8.0.tar.g ...
- Google Map API 学习五
今天其实收货很大的 1.InfoWindow google.maps.InfoWindow class An overlay that looks like a bubble and is often ...
- MyEclipse Spring被删之后,如何在myeclipse里面重新导入
1.找到项目文件 2.用记事本打开 .project 把里面涉及到spring的全部删除就可以了.
- vs未找到导入的项目,请确认 <Import> 声明中的路径正确
当使用vs出现下列情况: D:\xxxx\Web\Web.csproj : error : 无法读取项目文件“Web.csproj”. D:\xxxx\WebServiceManager\Web\W ...
- oracle查询语句2【转载】
本文使用的实例表结构与表的数据如下: scott.emp员工表结构如下: SQL> DESC SCOTT.EMP; Name Type Nullable Defaul ...
- ubuntu下使用ngrok外网映射
好久之前想搞明白这个事情,可是就是不知道这个词叫外网映射,所以也一直不知怎么做,在慕课网看用java开发微信公众号的时候教程里提到了外网映射,查了一些资料终于把本地给映射到外网了,直接变成了80端口, ...