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 会把所有的模块打包成单个文件.单个文件在大多数情况下是 ...
随机推荐
- android 一个页面内 多个listview的实现
如果很平常的两个listview组件竖直放在linearLayout布局中,结果是: 两个listview 很独立,中间似乎有个分割线,完全吧他们分离了,各自独立滚动,如果上面的listview把整个 ...
- Python中classmethod与staticmethod区别
classmethod:类方法staticmethod:静态方法 在python中,静态方法和类方法都是可以通过类对象和类对象实例访问.但是区别是: @classmethod 是一个函数修饰符,它表示 ...
- 实现对properties文件的有序读写
最近遇到一项需求,要求把properties文件中的内容读取出来供用户修改,修改完后需要再重新保存到properties文件中.很简单的需求吧,可问题是Properties是继承自HashTable的 ...
- Bluetooth LE(低功耗蓝牙) - 第五部分
回顾: 在本系列前面的文章中我们完成了发现BLE传感器并与之建立连接.现在只剩下从其中获取数据了,但是这并没有看起来那么简单.在这篇文章中我们将讨论GATT的特点以及如何促进主机与传感器之间的数据交换 ...
- lazyman学习
1.安装: gem install lazyman 2.建立工程: cd到工程目录下 lazyman new 工程名 3.打开调试命令 lazyman c lazyman调用selenium-webd ...
- .net开源工作流引擎ccflow
关于济南驰骋信息技术有限公司的.net开源工作流引擎 驰骋工作流引擎,工作流程管理系统:简称ccflow,驰骋一体化解决方案简称ccport. ccflow是济南驰骋信息技术有限公司向社会提供的一款1 ...
- Unity Skin Shader Optimized
Shader "Skin Shader" { Properties { _MainTex ("Diffuse (RGB)", 2D) = "white ...
- maya绝招(60---尾)
第64招 置换新意 Displacement(置换)和Bump(凹凸)效果类似,但运行方式不同.将一个File结点用中间拖动到材质上有的shading Group属性中的置换属性上,这个时候可以看到o ...
- linux平台MongoDB数据库安装
跟Ruiy哥一起玩转吧; <一,初始化玩转MongoDB> 1,关闭SElinux(Ruiy哥根据经验知红帽的SElinux架设就是个错误,还记得不管啥结构首先要关闭的就是它); 2,设置 ...
- weekend110(Hadoop)的 第七天笔记
(2015年1月31日) 课程目录 01-storm基本概念 02-storm编程规范及demo编写 03-storm的topology提交执行 04-kafka介绍 05-kafka集群部署及客户端 ...