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.更为强大的是,这个应用是真正的产品网站:就是它的官网.我有理由相信,这个网站是从源代码直接发布的,从网 ...
随机推荐
- ABAP术语-Update Module
Update Module 原文:http://www.cnblogs.com/qiangsheng/archive/2008/03/20/1114178.html Part of an update ...
- jdbc之存储过程的调用和调用方法
调用存储过程 调用存储过程的sql语句 {call 过程名称(参数列表)} conn = DbUtils.getConnection(); sql = "{call p_order_appr ...
- leetcode记录-组合两个表
表1: Person +-------------+---------+ | 列名 | 类型 | +-------------+---------+ | PersonId | int | | Firs ...
- 20155235 2016-2017-2 《Java程序设计》第9周学习总结
20155235 2016-2017-2 <Java程序设计>第9周学习总结 教材学习内容总结 第十六章 整合数据库 JDBC入门 JDBC简介 连接数据库 使用Statement.Res ...
- WPF 动画:同为控件不同命 - 简书
原文:WPF 动画:同为控件不同命 - 简书 1. 及格与优秀 读大学的时候,有一门课的作业是用 PPT 展示. 但是我们很多同学都把 PPT 当做 Word 来用,就单纯地往里面堆文字. 大家都单纯 ...
- RHCSA day5
4.调整逻辑卷容量 请按照以下要求调整本地逻辑卷lvm1的容量: 调整后的逻辑卷及文件系统大小为770MiB 调整后确保文件系统中已存在的内容不能被破坏 调整后的容量可能出现误差,只要在730MiB ...
- CentOS 6.8 curl支持的NSS修改为OpenSSL的方法
在CentOS 6.8的系统里面的curl支持的https是nss版本的,而不是openssl,所以在php使用curl访问https的时候会报Unable to load client key -8 ...
- 试用一下markdown
1 2 3 4 5 6 Blog
- python基础——字符串
Python的核心数据类型--字符串 常见字符串常量和表达式 操作 解释 s = '' 空字符串 s = "dodo's" 双引号和单引号 s = 'd\no\p\td\x00o' ...
- C# VS,连接到oracle 报要升级到8.多少版本的错
1:确定服务器的oracle版本 2:本地的客户端版本要和服务器一致 3:操作系统位数要一致