基于Nodejs的自动化工具Gulp学习

来源:互联网 发布:java base64 编辑:程序博客网 时间:2024/05/20 11:22

一.gulp简介

gulp是前端开发过程中一种基于流的代码构建工具,是自动化项目的构建利器;她不仅能对网站资源进行优化,而且在开发过程中很多重复的任务都能使用正确的工具自动完成;使用它,不仅可以很愉快的编写代码,而且大大提高我们的工作效率。
gulp是基于Nodejs的自动任务运行器,她能自动完成JavaScript,coffee,sass,less,html/image,css等文件的测试,检查,合并,压缩,格式化,浏览器自动刷新,部署文件生成,并监听文件在改动后重复指定的这些步骤。在实现上,她借鉴了Unix操作系统的管道(pipe)思想,前一级的输出,直接变成后一级的输入,使得在操作上非常简单。
流(stream)
流,简单来说就是建立在面向对象基础上的一种抽象的处理数据的工具。在流中,定义了一些处理数据的基本操作,如读取数据,写入数据,程序员是对流进行所有操作的,而不用关心流的另一头数据的真正流向。流不但可以处理文件,还可以处理动态内存,网络数据等多种数据形式。
gulp正是通过流和代码优于配置的策略来尽量简化任务编写的工作,这看起来有点像”jquery”的方法,把动作串起来构建任务。早在Unix的初期,流就已经存在了。流在Nodejs生态系统中也扮演了重要的角色,类似于*nix将几乎所有设备抽象为文件一样,Node将几乎所有的io操作都抽象成了stream的操作。因此用gulp编写任务也可看做是用nodejs编写任务。当使用流时,gulp去除了中间件,只将最后的输出写入磁盘,所以快。

二.Gulp的使用

(1)安装
安装Nodejs后,以全局方式安装gulp:

npm install -g gulp

全局安装gulp后,还需要在每个使用gulp的项目中单独安装一次。把目录切换到项目目录下

npm install gulp

如果在安装的时候想把gulp写进package.json文件的依赖中,则可以加上-save-dev:

npm install --save-dev  gulp

完成安装,应用。
(2)使用
gulp也需要一个文件作为它的主文件,在gulp种这个文件叫做gulpfile.js文件,然后放到项目目录中,之后要做的事就是在gulpfile.js中定义我们的任务了。例如:

var gulp = require('gulp');gulp.task('default',function(){    console.log('hello world');});

此时我们的目录结构是这样的

运行gulp任务
要运行gulp任务,只需切换到存放gulpfile.js文件的目录(windows平台请使用cmd或者Power Shell等工具),然后在命令行中执行gulp命令就行了,gulp后面可以加上要执行的任务名,例如gulp task1,如果没有指定任务名,则会执行任务名为default的默认任务。
gulp的工作方式是:在gulp中,使用的是Nodejs中的stream(流),首先获取到需要的stream,然后可以通过stream的pipe()方法把流导入到你想要的地方,比如gulp的插件中,经过插件处理后的流又可以继续导入到其他插件中,当然也可以把流写入到文件中。所以gulp是以stream为媒介的,它不需要频繁的生成临时文件,这也是我们应用gulp的一个原因。
gulp的使用流程一般是:首先通过gulp.src()方法获取到想要处理的文件流,然后把文件流通过pipe方法导入到gulp的插件中,最后把经过插件处理后的流再通过pipe方法导入到gulp.dest()中,gulp.dest()方法则把流中的内容写入到文件中。例如:

var gulp = require('gulp');gulp.src('script/jquery.js')         // 获取流的api    .pipe(gulp.dest('dist/foo.js')); // 写放文件的api
0 0
原创粉丝点击