<div class="jb51code">
<pre class="brush:bash;">
npm install gulp --save-dev
<div class="jb51code">
<pre class="brush:bash;">
npm install gulp --save-dev
在根目录下新建package.json文件
安装好后再次输入gulp -v查看版本号,如下图显示则为成功:
sass的编译 (gulp-ruby-sass) 自动添加css前缀 (gulp-autoprefixer) 压缩css (gulp-minify-css) js代码校验 (gulp-jshint) 合并js文件 (gulp-concat) 压缩js代码 (gulp-uglify) 压缩图片 (gulp-imagemin) 自动刷新页面 (gulp-livereload) 图片缓存,只有图片替换了才压缩 (gulp-cache) 更改提醒 (gulp-notify) 清除文件 (del) 安装这些插件需要运行如下命令:
$ npm install gulp-ruby-sass gulp-autoprefixer gulp-minify-css gulp-jshint gulp-concat gulp-uglify gulp-imagemin gulp-notify gulp-rename gulp-livereload gulp-cache del --save-dev
gulp.task(name[,deps],fn) 定义任务 name:任务名称 deps:依赖任务名称 fn:回调函数
gulp.run(tasks...):尽可能多的并行运行多个task
gulp.watch(glob,fn):当glob内容发生改变时,执行fn
gulp.src(glob):置需要处理的文件的路径,可以是多个文件以数组的形式,也可以是正则
gulp.dest(path[,options]):设置生成文件的路径 glob:可以是一个直接的文件路径。他的含义是模式匹配。 gulp将要处理的文件通过管道(pipe())API导向相关插件。通过插件执行文件的处理任务。
gulp.task这个API用来创建任务,在命令行下可以输入$ gulp [default],(中括号表示可选)来执行上面的任务。
gulp官方API文档:https://github.com/gulpjs/gulp/blob/master/docs/API.md
gulp 插件大全:http://gulpjs.com/plugins/
gulp.task('compress',function(){
return gulp.src('script/*.js')
.pipe(uglify())
.pipe(gulp.dest('dist'));
});
注:gulpfile.js文件名不可更改。 项目需要用到uglify和rename插件,执行以下命令安装:
以我的为例,进入gulpfile.js所在目录:
然后输入:
该命令会安装package.json下的全部依赖,如下图所示:
// 脚本
gulp.task('scripts',function() {
return gulp.src('src/scripts/*/.js')
.pipe(jshint('.jshintrc'))
.pipe(jshint.reporter('default'))
.pipe(concat('main.js'))
.pipe(gulp.dest('dist/scripts'))
.pipe(rename({ suffix: '.min' }))
.pipe(uglify())
.pipe(gulp.dest('dist/scripts'))
.pipe(notify({ message: 'Scripts task complete' }));
});
// 图片
gulp.task('images',function() {
return gulp.src('src/images/*/')
.pipe(cache(imagemin({ optimizationLevel: 3,progressive: true,interlaced: true })))
.pipe(gulp.dest('dist/images'))
.pipe(notify({ message: 'Images task complete' }));
});
// 清理
gulp.task('clean',function() {
return gulp.src(['dist/styles','dist/scripts','dist/images'],{read: false})
.pipe(clean());
});
// 预设任务
gulp.task('default',['clean'],function() {
gulp.start('styles','scripts','images');
});
// 看守
gulp.task('watch',function() {
// 看守所有.scss档
gulp.watch('src/styles/*/.scss',['styles']);
// 看守所有.js档
gulp.watch('src/scripts/*/.js',['scripts']);
// 看守所有图片档
gulp.watch('src/images/*/',['images']);
// 建立即时重整伺服器
var server = livereload();
// 看守所有位在 dist/ 目录下的档案,一旦有更动,便进行重整
gulp.watch(['dist/**']).on('change',function(file) {
server.changed(file.path);
});
});
注:pipe()是stream模块里传递数据流的一个方法,第一个参数为插件方法,插件会接收从上游流下的文件,进行处理加工后,再往下流。
gulp.task('deploy',function() {
return gulp.src('./dist/*/')
.pipe(ghPages());
});
gulp-jade插件:将jade编译成html文件 gulp-less插件:将less编译成css文件
gulp.task('less',function () {
return gulp.src('./less/*/.less')
.pipe(less({
paths: [ path.join(__dirname,'less','includes') ]
}))
.pipe(gulp.dest('./public/css'));
});
gulp-live-server 插件:方便的,轻量级的服务器
var gulp = require('gulp');
var gls = require('gulp-live-server');
gulp.task('serve',function() {
//1. serve with default settings
var server = gls.static(); //equals to gls.static('public',3000);
server.start();
//2. serve at custom port
var server = gls.static('dist',8888);
server.start();
//3. serve multi folders
var server = gls.static(['dist','.tmp']);
server.start();
//use gulp.watch to trigger server actions(notify,start or stop)
gulp.watch(['static/*/.css','static/*/.html'],function (file) {
server.notify.apply(server,[file]);
});
});
gulp-livereload,可以实时保存刷新,那样就不用按F5和切换界面了 gulp-load-plugins:在你的package.json文件中自动加载任意的gulp插件
例如一个给定的package.json文件如下:
"gulp-jshint": "*","gulp-concat": "*"
}
}
var plugins = gulpLoadPlugins();
plugins.jshint = require('gulp-jshint');
plugins.concat = require('gulp-concat');
gulp-babel:gulp 的babel插件,
使用方法:
官方github: https://github.com/gulpjs/gulp