gulp完全开发指南 => 快来换掉你的Grunt吧

最近一直在构建Angular应用,通过bower管理前端包依赖,然后通过gulp和它配合.发现gulp相比于grunt真的很轻,现在我的项目中已经取代了grunt.这里把我的一些实践贴记录下来和大家分享一下.

gulp定位和grunt一样也是前端构建工具,和grunt相比它更突出一个流的概念,它所有的任务执行都是one by one的感觉,官网的自定义就是:

gulp‘s use of streams and code-over-configuration makes for a simpler and more intuitive build.

首先我感觉它重量级较grunt轻了很多,上手相对简单,同时处理上也能满足我们的需求.这里通过一个真实项目的配置文件说明一下该怎么用gulp.

npm install -g gulp

局部安装在你的项目

npm install --save-dev gulp

两种安装方式随意,没什么好说的.

(2) 运行

在目录下创建一个"gulpfile.js"文件,通过gulp命令运行即可.

(3) gulpfile.js文件

这是一个完整的例子,已经运用在我项目中,已经加了注释,看完整个文件你对于gulp应该就已经了解并可以使用了.

var gulp = require(‘gulp‘);

// 引入组件
var less = require(‘gulp-less‘),            // less
    minifycss = require(‘gulp-minify-css‘), // CSS压缩
    uglify = require(‘gulp-uglify‘),        // js压缩
    concat = require(‘gulp-concat‘),        // 合并文件
    rename = require(‘gulp-rename‘),        // 重命名
    clean = require(‘gulp-clean‘);          //清空文件夹

// less解析
gulp.task(‘build-less‘, function(){
  gulp.src(‘./javis/static/less/lib/s-production.less‘)
    .pipe(less())
    .pipe(gulp.dest(‘./javis/static/build/css/lib/‘))

  gulp.src(‘./javis/static/less/lib/s-skins.less‘)
    .pipe(less())
    .pipe(gulp.dest(‘./javis/static/build/css/lib/‘))

  gulp.src(‘./javis/static/less/lib/s/s.less‘)
    .pipe(less())
    .pipe(gulp.dest(‘./javis/static/build/css/lib/‘))

  gulp.src(‘./javis/static/less/*.less‘)
    .pipe(less())
    .pipe(gulp.dest(‘./javis/static/build/css/‘))
});

// 合并、压缩、重命名css
gulp.task(‘stylesheets‘,[‘build-less‘], function() {
    // 注意这里通过数组的方式写入两个地址,仔细看第一个地址是css目录下的全部css文件,第二个地址是css目录下的areaMap.css文件,但是它前面加了!,这个和.gitignore的写法类似,就是排除掉这个文件.
  gulp.src([‘./javis/static/build/css/*.css‘,‘!./javis/static/build/css/areaMap.css‘])
    .pipe(concat(‘all.css‘))
    .pipe(gulp.dest(‘./javis/static/build/css/‘))
    .pipe(rename({ suffix: ‘.min‘ }))
    .pipe(minifycss())
    .pipe(gulp.dest(‘./javis/static/build/css‘));
});

// 合并,压缩js文件
gulp.task(‘javascripts‘, function() {
  gulp.src(‘./javis/static/js/*.js‘)
    .pipe(concat(‘all.js‘))
    .pipe(gulp.dest(‘./javis/static/build/js‘))
    .pipe(rename({ suffix: ‘.min‘ }))
    .pipe(uglify())
    .pipe(gulp.dest(‘./javis/static/build/js‘));
});

// 清空图片、样式、js
gulp.task(‘clean‘, function() {
  return gulp.src([‘./javis/static/build/css/all.css‘,‘./javis/static/build/css/all.min.css‘], {read: false})
    .pipe(clean({force: true}));
});

// 将bower的库文件对应到指定位置
gulp.task(‘buildlib‘,function(){

  gulp.src(‘./bower_components/angular/angular.min.js‘)
      .pipe(gulp.dest(‘./javis/static/build/js/‘))

  gulp.src(‘./bower_components/angular/angular.js‘)
      .pipe(gulp.dest(‘./javis/static/build/js/‘))

  gulp.src(‘./bower_components/bootstrap/dist/js/bootstrap.min.js‘)
      .pipe(gulp.dest(‘./javis/static/build/js/‘))

  gulp.src(‘./bower_components/jquery/dist/jquery.min.js‘)
      .pipe(gulp.dest(‘./javis/static/build/js/‘))

  gulp.src(‘./bower_components/angular-route/angular-route.min.js‘)
      .pipe(gulp.dest(‘./javis/static/build/js/‘))

  gulp.src(‘./bower_components/angular-animate/angular-animate.min.js‘)
      .pipe(gulp.dest(‘./javis/static/build/js/‘))

  gulp.src(‘./bower_components/angular-bootstrap/ui-bootstrap.min.js‘)
      .pipe(gulp.dest(‘./javis/static/build/js/‘))

  gulp.src(‘./bower_components/angular-bootstrap/ui-bootstrap-tpls.min.js‘)
      .pipe(gulp.dest(‘./javis/static/build/js/‘))

  //--------------------------css-------------------------------------

  gulp.src(‘./javis/static/less/fonts/*‘)
      .pipe(gulp.dest(‘./javis/static/build/css/fonts/‘))

  gulp.src(‘./bower_components/bootstrap/fonts/*‘)
      .pipe(gulp.dest(‘./javis/static/build/css/fonts/‘))

  gulp.src(‘./bower_components/bootstrap/dist/css/bootstrap.min.css‘)
      .pipe(gulp.dest(‘./javis/static/build/css/lib‘))

});

// 定义develop任务在日常开发中使用
gulp.task(‘develop‘,function(){
  gulp.run(‘buildlib‘,‘build-less‘,‘javascripts‘,‘stylesheets‘);

  gulp.watch(‘./javis/static/less/*.less‘, [‘build-less‘]);
});

// 定义一个prod任务作为发布或者运行时使用
gulp.task(‘prod‘,function(){
  gulp.run(‘buildlib‘,‘build-less‘,‘stylesheets‘,‘javascripts‘);

  // 监听.less文件,一旦有变化,立刻调用build-less任务执行
  gulp.watch(‘./javis/static/less/*.less‘, [‘build-less‘]);
});

// gulp命令默认启动的就是default认为,这里将clean任务作为依赖,也就是先执行一次clean任务,流程再继续.
gulp.task(‘default‘,[‘clean‘], function() {
  gulp.run(‘develop‘);
});

个人感觉如果使用过grunt那么看这个完全没难度,即使什么都没用过也大概能知道是什么意思.

上面通过gulp实现了less解析,js和css文件的合并,压缩,重命名,以及文件监听,清理等.注意一下上面require进来的插件需要你自己手动npm安装一下,具体的插件都有哪些以及对应安装可以看一下官网的plugin板块,很简单也很详细.这里仅列出一些常用的.

gulp-ruby-sass: 支持sass 
gulp-minify-css: 压缩css 
gulp-jshint: 检查js 
gulp-uglify: 压缩js 
gulp-concat: 合并文件 
gulp-rename: 重命名文件 
gulp-htmlmin: 压缩html 
gulp-clean: 清空文件夹

最后附上官网: http://gulpjs.com/

时间: 2024-12-14 10:05:23

gulp完全开发指南 => 快来换掉你的Grunt吧的相关文章

Vista/Win7 UAC兼容程序开发指南

mnesia在频繁操作数据的过程可能会报错:** WARNING ** Mnesia is overloaded: {dump_log, write_threshold},可以看出,mnesia应该是过载了.这个警告在mnesia dump操作会发生这个问题,表类型为disc_only_copies .disc_copies都可能会发生. 如何重现这个问题,例子的场景是多个进程同时在不断地mnesia:dirty_write/2 mnesia过载分析 1.抛出警告是在mnesia 增加dump

WatchKit-Programming-Guide-Apple-Watch开发指南官方翻译及总结

鉴于CSDN的Markdown很多bug,大家请看这里: WatchKit-Programming-Guide-Apple-Watch开发指南官方翻译及总结 Overview ### Developing for Apple Watch Apple Watch可以让用户以一种很私密,不招摇的样式查看信息(官方文档是这样的哈,但是我想大多数人不会不招摇的查看Apple Watch上的信息??).用户可以在不拿出手机的情况下,通过查看Apple Watch快速的获取重要的信息. Apple Watc

开发指南专题十:JEECG微云快速开发平台--表单校验组件ValidForm

10.4Validform对象[方法支持链式调用] 如示例 var demo=$(".formsub").Validform(),那么demo对象会有以下属性和方法可以调用: tipmsg[object] 如:demo.tipmsg.s="error! no messageinputed."; 通过该对象可以修改除 tit 以外的其他提示文字,这样可以实现同一个页面的不同表单使用不同的提示文字. 具体可修改的提示文字 $.Tipmsg={//默认提示文字; tit:

转:Oculus Unity Development Guide开发指南(2015-7-21更新)

http://forum.exceedu.com/forum/forum.php?mod=viewthread&tid=34175 Oculus Unity Development Guide开发指南转载请保留原始地   http://t.cn/RAblKoh Oculus/GearVR开发者群 302294234 Welcometo the Unity Development GuideIntroduction简介Welcometo the Oculus Unity Developer Gui

Boost程序库完全开发指南——深入C++“准”标准库(第3版)

内容简介  · · · · · · Boost 是一个功能强大.构造精巧.跨平台.开源并且完全免费的C++程序库,有着“C++‘准’标准库”的美誉. Boost 由C++标准委员会部分成员所设立的Boost 社区开发并维护,使用了许多现代C++编程技术,内容涵盖字符串处理.正则表达式.容器与数据结构.并发编程.函数式编程.泛型编程.设计模式实现等许多领域,极大地丰富了C++的功能和表现力,能够使C++软件开发更加简捷.优雅.灵活和高效. <Boost程序库完全开发指南——深入C++“准”标准库(

jstorm开发指南-写个简单的jstorm应用

jstorm开发指南-写个简单的jstorm应用 发表于 2015-07-18   |   分类于 大数据   |   暂无评论 jstorm 是阿里巴巴开源的基于storm采用Java重写的一套分布式实时流计算框架,使用简单,特点如下: 开发非常迅速: 接口简单,容易上手,只要遵守Topology,Spout, Bolt的编程规范即可开发出一个扩展性极好的应用,底层rpc,worker之间冗余,数据分流之类的动作完全不用考虑. 扩展性极好:当一级处理单元速度,直接配置一下并发数,即可线性扩展性

关于《Swift开发指南》背后的那些事

时间轴(倒叙)2014年8月底在图灵出版社的大力支持下,全球第一本全面.系统.科学的,包含本人多年经验的呕心沥血之作<Swift开发指南>(配有同步视频课程和同步练习)全线重磅推出2014年7月5日苹果宣布Swift语言二十天后,<Swift开发指南>第一稿交予图灵出版社2014年6月9日苹果宣布Swift语言三天后,启动<Swift开发指南>撰写2014年6月2日凌晨1点(北京时间:)在苹果开发者大会WWDC 2014上,苹果宣布了全新的iOS及OS X平台开发语言S

JNI/NDK开发指南(五)——访问数组(基本类型数组与对象数组)

转载请注明出处:http://blog.csdn.net/xyang81/article/details/42346165 JNI中的数组分为基本类型数组和对象数组,它们的处理方式是不一样的,基本类型数组中的所有元素都是JNI的基本数据类型,可以直接访问.而对象数组中的所有元素是一个类的实例或其它数组的引用,和字符串操作一样,不能直接访问Java传递给JNI层的数组,必须选择合适的JNI函数来访问和设置Java层的数组对象.阅读此文假设你已经了解了JNI与Java数据类型的映射关系,如果还不了解

Knockout应用开发指南

第一章:入门 1.Knockout简介 (Introduction) Knockout是一个轻量级的UI类库,通过应用MVVM模式使JavaScript前端UI简单化. Knockout有如下4大重要概念: 声明式绑定 (Declarative Bindings):使用简明易读的语法很容易地将模型(model)数据关联到DOM元素上. UI界面自动刷新 (Automatic UI Refresh):当您的模型状态(model state)改变时,您的UI界面将自动更新. 依赖跟踪 (Depend