gulp配置文件(gulpfile.js)
需要安装的插件
"gulp": "^3.9.1",
"gulp-clean": "^0.3.2",
"gulp-concat": "^2.6.1",
"gulp-connect": "^5.0.0",
"gulp-cssmin": "^0.2.0",
"gulp-imagemin": "^3.3.0",
"gulp-less": "^3.3.2",
"gulp-load-plugins": "^1.5.0",
"gulp-minify-css": "^1.2.4",
"gulp-uglify": "^3.0.0",
"open": "0.0.5",
"serve": "^6.0.0"
npm i --save-dev gulp gulp-clean gulp-concat gulp-connect gulp-imagemin gulp-less gulp-load-plugins gulp-minify-css gulp-uglify open serve
<script>
var gulp=require('gulp');
var $=require('gulp-load-plugins')();//实例化 方便调用 gulp-minify-css gulp-uglify
var open=require('open'); // 实例化open方法
var app={
srcPath:'src/', //开发目录
devPath:'build/', //生产目录
prdPath:'dist/'//发布目录(用于发布)
}; gulp.task('lib',function () { //为事件命名
gulp.src('bower_comments/**/*.js') //复制项目所依赖的js(如:通过bower安装的angular.js)
.pipe(gulp.dest(app.devPath+'vendor')) //将文件黏贴到生产目录
.pipe(gulp.dest(app.prdPath+'vendor')) //将文件黏贴到发布目录
.pipe($.connect.reload()); //监测文件改变后重新运行黏贴复制
}); gulp.task('html',function () {
gulp.src(app.srcPath+'**/*.html') //复制开发目录下的所有html文件
.pipe(gulp.dest(app.devPath)) //将文件黏贴到生产目录
.pipe(gulp.dest(app.prdPath)) //将文件黏贴到发布目录
.pipe($.connect.reload());
}); gulp.task('json',function () {
gulp.src(app.srcPath+'data/**/*.json') //复制开发目录下的所有json文件
.pipe(gulp.dest(app.devPath+'data'))
.pipe(gulp.dest(app.prdPath+'data'))
.pipe($.connect.reload());
}); gulp.task('less',function () {
gulp.src(app.srcPath+'style/index.less')
.pipe($.less()) //将less文件编译为css
.pipe(gulp.dest(app.devPath+'css')) //将编译后的css文件黏贴到生产目录
.pipe($.minifyCss()) //用gulp-minify-css压缩css文件
.pipe(gulp.dest(app.prdPath+'css')) //
.pipe($.connect.reload());
});
gulp.task('css',function () {
gulp.src(app.srcPath+"style/*.css")
.pipe(gulp.dest(app.prdPath+'css'))
.pipe(gulp.dest(app.devPath+"css"))
.pipe($.connect.reload());
});
gulp.task('js',function () {
gulp.src(app.srcPath+'script/**/*.js')
.pipe($.concat('index.js'))
.pipe(gulp.dest(app.devPath+'js'))
.pipe($.uglify()) //用gulp-uglify压缩js文件
.pipe(gulp.dest(app.prdPath+'js'))
.pipe($.connect.reload());
}); gulp.task('img',function () {
gulp.src(app.srcPath+'image/**/*')
.pipe($.imagemin()) //通过 gulp-imagemin 压缩图片文件
.pipe(gulp.dest(app.devPath+"image"))
.pipe(gulp.dest(app.prdPath+'image'))
.pipe($.connect.reload());
}); gulp.task('build',['img','less','js','html','lib','json','css']); //将多个命令整合为一个命令方便运行 gulp.task('serve',['build'],function () { //开启一个本地服务器,方便浏览调试
$.connect.server({ //
root:[app.prdPath], // 设置服务器根目录
livereload:true, //启动服务,自动打开浏览器(低端浏览不支持)
port:1234 //定义本地浏览器端口号(不与其他端口冲突任意定义)
});
open('http://localhost:1234'); //打开本地服务器的主页
gulp.watch(app.srcPath+'script/**/*.js',['js']); //监听js文件目录,文件改变重新启动 js 任务
// gulp.watch('bower_comments/**/*',['lib']);
gulp.watch(app.srcPath+'style/**/*.less',['less']);//监听less文件目录,文件改变重新启动 less 任务
gulp.watch(app.srcPath+'**/*.html',['html']);
gulp.watch(app.srcPath+'data/**/*.json',['json']);
gulp.watch(app.srcPath+'image/**/*',['img']); }); gulp.task('clean',function () { //清除 生产目录 和发布目录的全部文件
gulp.src([app.devPath,app.prdPath])
.pipe($.clean())
}); gulp.task('default',['serve']); //定义一个默认任务, 在命令行中只需要 输入 gulp 不需要 跟任务名
</script>
gulp配置文件(gulpfile.js)的更多相关文章
- gulpfile.js不断更新中...
Gulp压缩合并js/css文件,压缩图片,以及热更新教程 var gulp = require('gulp');var concat = require('gulp-concat');//- 多个文 ...
- gulp的使用(二)之gulpfile.js文件的配置
Gulpfile.js是什么文件: gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器:她不仅能对网站资源进行优化,而且在开发过程中很多重复的任务能够使用正确的工具自动完成:使用她, ...
- gulp 图片、样式、js、实时刷新等压缩gulpfile.js文件各个模块
1.压缩tinypng图片 gulp-tinypng-nokey,但不压缩gif格式(另外一个gulp-imagemin压缩率不高,可以压缩gif格式) // 获取 gulp var gulp = ...
- gulpfile.js 合并压缩 requirejs 的配置文件
var gulp = require("gulp"); // var babel = require("gulp-babel"); // 用于ES6转化ES5 ...
- gulpfile.js文档
gulp watch 实现监听不仅需要package.json文档,还需要gulpfile.js文档.否则无法实现. 1.gulp的安装 1.1 首先必须先安装node.js.这个可以参考之前的博客& ...
- gulp为css,js添加版本号
由于cdn缓存,更改样式后会有一段时间不生效,解决方法就是给css,js加上版本号效果如下: 1.安装gulp插件 npm install --save-dev gulp-rev (version:9 ...
- gulp学习-gulpfile
安装gulp 假设已经安装了node 和npm (淘宝的cnpm很适合国内使用). 1.首页全局安装gulp. 1 npm install --global gulp 2.其次局部安装gulp.(注: ...
- gulp实现打包js/css/img/html文件,并对js/css/img文件加上版本号
参考打包教程: http://www.cnblogs.com/tugenhua0707/p/4069769.html http://www.cnblogs.com/tugenhua0707/p/498 ...
- 通过Anuglar Material串串学客户端开发 - javascript编译和gulpfile.js
Angular Material不仅仅有本身框架的源代码,还有在这个框架上实现的一个应用docs.更为强大的是,这个应用是真正的产品网站:就是它的官网.我有理由相信,这个网站是从源代码直接发布的,从网 ...
随机推荐
- 【Python】01 - 常见用法随见随梳理
1. range() 和 xrange()的区别 for x in range(5): print x for x in xrange(5): print x 这么看,range和xrange返回的值 ...
- C++编译器是如何管理类和对象的,类的成员函数和成员变量
C++中的class从面向对象理论出发,将变量(属性)和函数(方法)集中定义在一起,用于描述现实世界中的类.从计算机的角度,程序依然由数据段(栈区内存)和代码段(代码区内存)构成. #include ...
- 虚拟机重启网络服务失败,当查看状态显示错误Failed to start LSB......
重启网络失败截图 从本质上来看出现这样的问题,是因为拷贝过来的虚拟机重新分配了网卡MAC地址.这样造成的结果是配置文件中MAC与当前网卡MAC不一致.所以只需要修改一下配置文件即可. 用ip addr ...
- 大数据学习之Hadoop快速入门
1.Hadoop生态概况 Hadoop是一个由Apache基金会所开发的分布式系统集成架构,用户可以在不了解分布式底层细节情况下,开发分布式程序,充分利用集群的威力来进行高速运算与存储,具有可靠.高效 ...
- 执行Go程序的三种方式及Go语言关键字
执行 Go 程序的三种方式及 Go 语言关键字 执行 Go 程序的三种方式 一.使用 go run 命令 二.使用 go build 命令 Step1. 对 go 源码源文件执行 go build 命 ...
- 自己第一次使用ANTLR遇到的问题
觉得既然是第一次尝试ANTLR嘛,那就来个简单点的,parse Windows 的 hosts 文件吧,结果...... 先上一段 grammar: grammar hosts; hostfile: ...
- 20155307 《Java程序设计》课堂实践项目MyOD
一开始没理解老师的要求,交的截图是错误的. import java.io.FileInputStream; import java.io.IOException; import java.io.Inp ...
- 自己在UWP程序上调用usb转串口的路程
之前一直是在普通的framework环境下写串口,使用的类为 SerialPort 这个类大家可能比较熟悉.但是在UWP的开发里,使用的是 SerialDevice 这个类,是不一样的. 1. 清单文 ...
- sql语句-2-字符串数字日期时间
- Hibernate框架用法
一,Hibernate框架介绍 没有Hibernate之前,使用jdbc来连接数据库时,需要反射加载驱动,再获取连接 在连接上获取sql承载块,传入sql语句执行,获取结果集,解析结果 Hiberna ...