前端读者 | 前端构建工具Gulp
@羯瑞 整理
前言
前端工具现在层出不穷,网上搜下一大片,就看你怎么去使用了,基于项目看用什么样的构建工具。有的工具提供的功能还是非常强大的。
- FIS。百度团队的产品。现在百度的多个产品中使用。面向前端的工程构建工具。解决前端工程中性能优化、资源加载(异步、同步、按需、预加载、依赖管理、合并、内嵌)、模块化开发、自动化工具、开发规范、代码部署等问题。学习成本相对比较高。官网
- CodeKit。自动编译Less, Sass, Stylus, CoffeeScript, Jade & Haml等文件致力于js文件合并和压缩,以及js语法错误检查同时还支持Compass(Sass伴侣)。这个只是知道而已没去深究,貌似百度搜文文章也不多。官网
- yeoman。Google的团队和外部贡献者团队合作开发的,他的目标是通过Grunt(一个用于开发任务自动化的命令行工具)和Bower(一个HTML、CSS、Javascript和图片等前端资源的包管理器)的包装为开发者创建一个易用的工作流。官网
- Bower。一个客户端技术的软件包管理器,它可用于搜索、安装和卸载如JavaScript、HTML、CSS之类的网络资源。其他一些建立在Bower基础之上的开发工具,如YeoMan和Grunt。官网
- webpack。一款模块加载器兼打包工具,它能把各种资源,例如JS(含JSX)、coffee、样式(含less/sass)、图片等都作为模块来使用和处理。官网
有兴趣的可以去了解下,上面的我也是一知半解的。
本文主角
构建工具大多都是居于nodejs下的。
说起gulp,就不得说下grunt。相信 很多小伙伴都会在网上看到它俩在一起的。下面是摘抄网上的对比:
- 易用 Gulp相比Grunt更简洁,而且遵循代码优于配置策略,维护Gulp更像是写代码。
- 高效 Gulp相比Grunt更有设计感,核心设计基于Unix流的概念,通过管道连接,不需要写中间文件。
- 高质量 Gulp的每个插件只完成一个功能,这也是Unix的设计原则之一,各个功能通过流进行整合并完成复杂的任务。例如:Grunt的imagemin插件不仅压缩图片,同时还包括缓存功能。他表示,在Gulp中,缓存是另一个插件,可以被别的插件使用,这样就促进了插件的可重用性。目前官方列出的有673个插件。
- 易学 Gulp的核心API只有5个,掌握了5个API就学会了Gulp,之后便可以通过管道流组合自己想要的任务。
- 流 使用Grunt的I/O过程中会产生一些中间态的临时文件,一些任务生成临时文件,其它任务可能会基于临时文件再做处理并生成最终的构建后文件。而使用Gulp的优势就是利用流的方式进行文件的处理,通过管道将多个任务和操作连接起来,因此只有一次I/O的过程,流程更清晰,更纯粹。
- 代码优于配置 维护Gulp更像是写代码,而且Gulp遵循CommonJS规范,因此跟写Node程序没有差别。
gulp安装
先来说下npm工具,npm是随同NodeJS一起安装的包管理工具,装了node会默认装上npm工具。### 前言
前端工具现在层出不穷,网上搜下一大片,就看你怎么去使用了,基于项目看用什么样的构建工具。有的工具提供的功能还是非常强大的。
- 安装gulp之前,先安装nodejs环境,因为gulp是基于nodejs的前端构建工具。window平台下直接安装,一直下一步就行。百度搜下node官网就下得到安装包。
- 全局安装gulp。cmd模式下执行下面代码,--global全局安装。
npm install --global gulp
- 在开发项目上,安装项目依赖。如果gulp全局安装了,就不会再重新下载了。此操作会在项目目录中生成一个package.json依赖文件。--save生产环境,-dev开发环境。一般两者都会一起用。这个在package.json可以看出来区别。
npm install --save-dev gulp
- 在项目中新建gulpfile.js文件,写流程代码。下面是项目中用到的:
// 载入插件
var gulp = require('gulp'),
browserSync = require('browser-sync').create(),//浏览器刷新工具
imagemin = require('gulp-imagemin'),//图片压缩
tinypng = require('gulp-tinypng-nokey');//tinypng图片压缩
minifycss = require('gulp-minify-css'),//css压缩
uglify = require('gulp-uglify'),//js压缩
jshint = require('gulp-jshint'),//js语法检测
rename = require('gulp-rename'),//重命名
gclean = require('gulp-clean'),//清除文件
cache = require('gulp-cache'),//获取文件cache
minimist = require('minimist');//截取传参
/**
* 默认参数:vurl(模版路径),wurl(静态资源路径),ourl(输出路径)
* imagemin: 图片压缩,已经舍弃。压缩效果不怎么好,支持全部图片格式
* clean: 清除输出文件夹,防止输出的东西重叠,或者可以自定义不同文件夹的名称
* server: 实时刷新测试,自定义域名,自定义监听模版文件和静态资源
* picmin: 图片压缩基于tinypng,压缩率高,质量好。仅支持png,jpg。api请求所以会慢点
* cssmin: css文件压缩
* jsmin: js文件压缩
* allmin: cssmin+jsmin+picmin
*
* 优化内容:都自定义传递参数路径,符合我们一个系统多个站点的痛点;优化内存占用;引入缓存机制
* gulp imagemin --wurl ffsm/baobaoqm
* gulp clean --ourl aa_gulp_out
* gulp server --host dev.d1xz.net --vurl ffsm/view/qf --wurl ffsm/qf/diandeng
* gulp picmin --wurl ffsm/baobaoqm [--ourl aa_gulp_out]
* gulp cssmin --wurl ffsm/baobaoqm [--ourl aa_gulp_out]
* gulp jsmin --wurl ffsm/baobaoqm [--ourl aa_gulp_out]
* gulp allmin --wurl ffsm/baobaoqm [--ourl aa_gulp_out]
*/
var viewUrl='d1xz/shuipf/application/';
var wwwUrl='d1xz/www/statics/';
// 获取配置参数
var options = minimist(process.argv.slice(2));
//IMG压缩 支持GIF、PNG、JPG压缩率不高
gulp.task('imagemin',['clean'],function(){
if(options.wurl){
var thisUrl = wwwUrl+''+options.wurl;
var outUrl = options.ourl?options.ourl:thisUrl;
console.log('压缩地址路径:'+thisUrl);
console.log('输出地址路径:'+outUrl);
gulp.src([wwwUrl+''+options.url+'/*.{gif,png,jpg,jpeg}',wwwUrl+''+options.url+'/**/*.{gif,png,jpg,jpeg}'])
.pipe(imagemin())
.pipe(gulp.dest(outUrl));
}else{
console.log('配置参数错误;例:gulp imagemin --wurl ffsm/baobaoqm');
}
});
// 清除输出文件
gulp.task('clean', function() {
if(options.ourl){
return gulp.src(options.ourl, {read: false}).pipe(gclean());
}else{
console.log('配置参数错误;例:gulp clean --ourl aa_gulp_out');
}
});
//HTML实时预览
gulp.task('server', function() {
console.log('为减少系统cpu、内存占用,请写全路径;');
if(options.host){
browserSync.init({
proxy:options.host,//动态域名
notify: false,//刷新是否提示
open: true,//是否自动打开页面
timestamps: true
});
//监听文件变化数组
var vurl=viewUrl+''+options.vurl;
var wurl=wwwUrl+''+options.wurl;
console.log('监听模版文件路径:'+vurl);
console.log('监听静态文件路径:'+wurl);
gulp.watch([vurl+'/*.*',vurl+'/**/*.*',wurl+'/*.*',wurl+'/**/*.*']).on("change", browserSync.reload);
}else{
console.log('配置参数错误;例:gulp server --host dev.d1xz.net --vurl ffsm/view/qf --wurl ffsm/qf/diandeng');
}
});
// 图片压缩tinypng,api请求速度会慢点;只能压缩PNG和JPG
gulp.task('picmin', function () {
if(options.wurl){
var thisUrl = wwwUrl+''+options.wurl;
var outUrl = options.ourl?options.ourl:thisUrl;
console.log('压缩地址路径:'+thisUrl);
console.log('输出地址路径:'+outUrl);
gulp.src([thisUrl+'/*.{png,jpg,jpeg}',thisUrl+'/**/*.{png,jpg,jpeg}','!'+thisUrl+'/layer/**/*.{png,jpg,jpeg}'])
.pipe(cache(tinypng()))
.pipe(gulp.dest(outUrl));
}else{
console.log('配置参数错误;例:gulp picmin --wurl ffsm/baobaoqm');
}
});
// css压缩
gulp.task('cssmin', function() {
if(options.wurl){
var thisUrl=wwwUrl+''+options.wurl;
var outUrl = options.ourl?options.ourl:thisUrl;
console.log('压缩地址路径:'+thisUrl);
console.log('输出地址路径:'+outUrl);
gulp.src([thisUrl+'/*.css',thisUrl+'/**/*.css','!'+thisUrl+'/**/*.min.css','!'+thisUrl+'/**/layer/**/*.css','!'+thisUrl+'/**/layui/**/*.css','!'+thisUrl+'/**/layer_mobile/**/*.css','!'+thisUrl+'/**/layer_mobile/**/*.css',,'!'+thisUrl+'/**/swiper/**/*.css','!'+thisUrl+'/**/swiper/**/*.css','!'+thisUrl+'/**/libs/**/*.css','!'+thisUrl+'/**/libs/*.css'])
.pipe(minifycss()) //执行压缩
.pipe(rename({suffix: '.min'})) //重命名
.pipe(gulp.dest(outUrl)); //输出文件夹
}else{
console.log('配置参数错误;例:gulp cssmin --wurl ffsm/baobaoqm');
}
});
// js压缩
gulp.task('jsmin', function() {
if(options.wurl){
var thisUrl=wwwUrl+''+options.wurl;
var outUrl = options.ourl?options.ourl:thisUrl;
console.log('压缩地址路径:'+thisUrl);
console.log('输出地址路径:'+outUrl);
gulp.src([thisUrl+'/**/*.js',thisUrl+'/*.js','!'+thisUrl+'/**/*.min.js','!'+thisUrl+'/**/layer/**/*.js','!'+thisUrl+'/**/layui/**/*.js','!'+thisUrl+'/**/require/**/*.js','!'+thisUrl+'/**/require/*.js','!'+thisUrl+'/**/layer_mobile/**/*.js','!'+thisUrl+'/**/layer_mobile/**/*.js','!'+thisUrl+'/**/swiper/**/*.js','!'+thisUrl+'/**/swiper/**/*.js','!'+thisUrl+'/**/libs/**/*.js','!'+thisUrl+'/**/libs/*.js'])
.pipe(jshint())
.pipe(uglify()) //执行压缩
.pipe(rename({suffix: '.min'})) //重命名
.pipe(gulp.dest(outUrl)); //输出文件夹
}else{
console.log('配置参数错误;例:gulp jsmin --wurl ffsm/baobaoqm');
}
});
// 全部压缩
gulp.task('allmin', function(){
gulp.start('cssmin', 'jsmin', 'picmin');
});
- 上面的注释都写的很清楚了,就不多阐述了。相关的可以去npm官网搜索相关插件看下具体的用法就行了。
一些问题
- 协同开发怎么共用gulp
package.json文件里写的插件依赖就派上用场了。在项目中直接执行下面代码就可以自动全部安装依赖插件了:
npm install
- npm下载缓慢
可以使用淘宝镜像具体用法移步:>淘宝npm镜像
//临时安装
npm --registry https://registry.npm.taobao.org install express
//持久安装(替换npm的源地址)
npm config set registry https://registry.npm.taobao.org
//安装cnpm(推荐)
npm install -g cnpm --registry=https://registry.npm.taobao.org
前端读者 | 前端构建工具Gulp的更多相关文章
- 前端构建工具gulp使用
前端自动化流程工具,用来合并文件,压缩等. Gulp官网 http://gulpjs.com/ Gulp中文网 http://www.gulpjs.com.cn/ Gulp中文文档 https://g ...
- 前端构建工具gulp
前端构建工具gulp使用 前端自动化流程工具,用来合并文件,压缩等. Gulp官网 http://gulpjs.com/ Gulp中文网 http://www.gulpjs.com.cn/ Gul ...
- 前端构建工具gulp使用 (转)
http://www.cnblogs.com/starof/p/5194622.html 前端自动化流程工具,用来合并文件,压缩等. Gulp官网 http://gulpjs.com/ Gulp中文网 ...
- 前端自动化构建工具gulp的使用总结
前端自动化构建工具gulp的使用总结 博主最近偶的空闲,在此对gulp的使用做一个总结,让小伙伴知道如何合理的使用gulp以及gulp的使用技巧. 谈到gulp,有人可能就会想到另外一个构建工具gru ...
- (转载)前端构建工具gulp使用
前端构建工具gulp使用 前端自动化流程工具,用来合并文件,压缩等. Gulp官网 http://gulpjs.com/ Gulp中文网 http://www.gulpjs.com.cn/ Gulp中 ...
- (转)前端构建工具gulp入门教程
前端构建工具gulp入门教程 老婆婆 1.8k 2013年12月30日 发布 推荐 10 推荐 收藏 83 收藏,20k 浏览 本文假设你之前没有用过任何任务脚本(task runner)和命令行工具 ...
- 前端构建工具gulp之基本介绍
1.基本介绍 gulp.js是一个自动化构建工具,是自动化项目的构建利器.可以对网站的资源进行优化,将开发过程中一些重复的任务通过执行命令自动完成.这样能很大的提高我们的工作效率. gulp.js是基 ...
- 怎么在项目中使用前端包管理器bower和构建工具gulp
下面以WeUI(微信官方网页开发样式库)介绍一下,怎么把WeUi引入到自己的项目中,我的开发环境Visual Studio 2012,当然了Visual Studio 2015对此已有了更好的支持(h ...
- 亚信UED前端流程自动化构建工具
亚信UED前端流程自动化构建工具 .wmd-input, .wmd-input:focus, #md-section-helper {font-size: 14px !important;line-h ...
随机推荐
- 字符串模式匹配算法--BF和KMP详解
1,问题描述 字符串模式匹配:串的模式匹配 ,是求第一个字符串(模式串:str2)在第二个字符串(主串:str1)中的起始位置. 注意区分: 子串:要求连续 (如:abc 是abcdef的子串) ...
- HDU1573 线性同余方程(解的个数)
X问题 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- MySQL和Postgresql的区别
一.PostgreSQL相对于MySQL的优势 1.在SQL的标准实现上要比MySQL完善,而且功能实现比较严谨:2.存储过程的功能支持要比MySQL好,具备本地缓存执行计划的能力:3.对表连接支持较 ...
- 【BZOJ】2679: [Usaco2012 Open]Balanced Cow Subsets
[算法]折半搜索+数学计数 [题意]给定n个数(n<=20),定义一种方案为选择若干个数,这些数可以分成两个和相等的集合(不同划分方式算一种),求方案数(数字不同即方案不同). [题解] 考虑直 ...
- 【BZOJ】1602:[Usaco2008 Oct]牧场行走
[算法]最近公共祖先(LCA) [题解] 点x,y到最近公共祖先z的距离之和相当于x,y到根的距离减去两倍z到根的距离, 即ans=dis[x]+dis[y]-2*dis[z] 记得边数组要开两倍!! ...
- Fiddler抓取HTTPS协议
HTTPS协议握手过程: 1,客户端明文请求,把自己支持的非对称加密算法(用于使用CA证书公钥加密计算生成协商密钥的随机数per_master).对称加密算法(用于以后使用协商密钥加密传输内容).验证 ...
- HTTPS加密通信原理及数字证书系统
https加密通信原理: 公钥私钥成对,公钥公之于众,私钥只有自己知道. 用公钥加密的信息只能由与之相对应的私钥解密. 甲给乙发送数据时,甲先用乙的公钥加密这段数据,再用自己的私钥对这段数据的特征数据 ...
- ubuntu 提速
linux的各大发行版,都有些不必要的服务被默认开启了,针对ubuntu,我们可以采用选择性关闭的方法加速起动,提高系统性能. 这里我们安装一个软件: sudo apt-get install sys ...
- 【转】debian下的update-rc.d的使用
在Linux系统下,一个Services的启动.停止以及重启通常是通过/etc/init.d目录下的脚本来控制的.然而,在启动或改变运行级别时, 是在/etc/rcX.d中来搜索脚本.其中X是运行级别 ...
- Laravel 5.2 整合 Uploadify 上传图片
前端: <!-- 引入CSS.JS --> <link rel="stylesheet" type="text/css" href=" ...