var app = { // 定义目录
srcPath:'src/',
buildPath:'build/',
distPath:'dist/'
}
//1.引入gulp与gulp插件 使用时,要去下载这些插件
var gulp = require('gulp');
var less = require('gulp-less');
var cssmin = require('gulp-cssmin');
var uglify = require('gulp-uglify');
var concat = require('gulp-concat');
var connect = require('gulp-connect');
var imagemin = require('gulp-imagemin');
var open = require('open');
//把bower下载的前端框架放到我们项目当中
gulp.task('lib',function () {
gulp.src('bower_components/**/*.js')
.pipe(gulp.dest(app.buildPath+'lib'))
.pipe(gulp.dest(app.distPath+'lib'))
.pipe(connect.reload()) //当内容发生改变时, 重新加载。
});
//2.定义任务 把所有html文件移动另一个位置
gulp.task('html',function () {
//要操作哪些文件 确定源文件地址
gulp.src(app.srcPath+'**/*.html') /*src下所有目录下的所有.html文件*/
.pipe(gulp.dest(app.buildPath)) //gulp.dest 要把文件放到指定的目标位置
.pipe(gulp.dest(app.distPath))
.pipe(connect.reload()) //当内容发生改变时, 重新加载。
});
//3.执行任务 通过命令行。gulp 任务名称
//定义编译less任务 下载对应的插件 gulp-less
//把less文件转成css放到build
gulp.task('less',function () {
gulp.src(app.srcPath+'style/index.less')
.pipe(less())
.pipe(gulp.dest(app.buildPath+'css/'))
/*经过压缩,放到dist目录当中*/
.pipe(cssmin())
.pipe(gulp.dest(app.distPath+'css/'))
.pipe(connect.reload())
});
//合并js
gulp.task('js',function () {
gulp.src(app.srcPath+'js/**/*.js')
.pipe(concat('index.js'))
.pipe(gulp.dest(app.buildPath+'js/'))
.pipe(uglify())
.pipe(gulp.dest(app.distPath+'js'))
.pipe(connect.reload())
});
//压缩图片
gulp.task('image',function () {
gulp.src(app.srcPath+'images/**/*')
.pipe(gulp.dest(app.buildPath+'images'))
.pipe(imagemin())
.pipe(gulp.dest(app.distPath+'images'))
.pipe(connect.reload())
});
//同时执行多个任务 [其它任务的名称]
// 当前bulid时,会自动把数组当中的所有任务给执行了。
gulp.task('build',['less','html','js','image','lib']);
//定义server任务
//搭建一个服务器。设置运行的构建目录
gulp.task('server',['build'],function () {
//设置服务器
connect.server({
root:[app.buildPath],//要运行哪个目录
livereload:true, //是否热更新。
port:8888 //端口号
})
//监听哪些任务
gulp.watch('bower_components/**/*',['lib']);
gulp.watch(app.srcPath+'**/*.html',['html']);
gulp.watch(app.srcPath+'js/**/*.js',['js']);
gulp.watch(app.srcPath+'images/**/*',['image']);
gulp.watch(app.srcPath+'style/**/*.less',['less']);
//通过浏览器把指定的地址 (http://localhost:9999)
open('http://localhost:8888');
});
//定义默认任务
//直接执行gulp 会调用的任务
gulp.task('default',['server']);
gitfile.js中的内容
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 摘自:http://blog.csdn.net/zhbitxhd/article/details/22291999...