需要安装的插件

"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)的更多相关文章

  1. gulpfile.js不断更新中...

    Gulp压缩合并js/css文件,压缩图片,以及热更新教程 var gulp = require('gulp');var concat = require('gulp-concat');//- 多个文 ...

  2. gulp的使用(二)之gulpfile.js文件的配置

    Gulpfile.js是什么文件: gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器:她不仅能对网站资源进行优化,而且在开发过程中很多重复的任务能够使用正确的工具自动完成:使用她, ...

  3. gulp 图片、样式、js、实时刷新等压缩gulpfile.js文件各个模块

    1.压缩tinypng图片   gulp-tinypng-nokey,但不压缩gif格式(另外一个gulp-imagemin压缩率不高,可以压缩gif格式) // 获取 gulp var gulp = ...

  4. gulpfile.js 合并压缩 requirejs 的配置文件

    var gulp = require("gulp"); // var babel = require("gulp-babel"); // 用于ES6转化ES5 ...

  5. gulpfile.js文档

    gulp watch 实现监听不仅需要package.json文档,还需要gulpfile.js文档.否则无法实现. 1.gulp的安装 1.1 首先必须先安装node.js.这个可以参考之前的博客& ...

  6. gulp为css,js添加版本号

    由于cdn缓存,更改样式后会有一段时间不生效,解决方法就是给css,js加上版本号效果如下: 1.安装gulp插件 npm install --save-dev gulp-rev (version:9 ...

  7. gulp学习-gulpfile

    安装gulp 假设已经安装了node 和npm (淘宝的cnpm很适合国内使用). 1.首页全局安装gulp. 1 npm install --global gulp 2.其次局部安装gulp.(注: ...

  8. gulp实现打包js/css/img/html文件,并对js/css/img文件加上版本号

    参考打包教程: http://www.cnblogs.com/tugenhua0707/p/4069769.html http://www.cnblogs.com/tugenhua0707/p/498 ...

  9. 通过Anuglar Material串串学客户端开发 - javascript编译和gulpfile.js

    Angular Material不仅仅有本身框架的源代码,还有在这个框架上实现的一个应用docs.更为强大的是,这个应用是真正的产品网站:就是它的官网.我有理由相信,这个网站是从源代码直接发布的,从网 ...

随机推荐

  1. Web开发生存工具使用指南

    这里安利两款我认为开发中能够极大的提高生产力的工具,Charles 和 Postman. P.S. Charles(查尔斯)..不要再读查理斯了,金刚狼中被老铁扎心的博士就叫 CharlesP.P.S ...

  2. Linux系统下连接校园网Drcom客户端教程(广东工业大学)

    这篇教程写给想要学习Linux系统或者在Linux系统下有需要使用Drcom上网的同学,在我疯狂踩坑,经过n多次的刷机装机实验,体验不同发行版本的linux系统后,终于懂得怎么连接上drcom,想想连 ...

  3. 时间戳Unix timestamp

    (1)定义 Unix时间戳(Unix timestamp),或称Unix时间(Unix time).POSIX时间(POSIX time),是一种时间表示方式,定义为从格林威治时间1970年01月01 ...

  4. zabbix-3.2.3安装

    环境:lapp 操作系统: rhel7.0apache: apache-2.4数据库: postgresql-9.2.10php: php-5.4.16-21zabbix: zabbix-3.2.3 ...

  5. 20155224 实验一《Java开发环境的熟悉》实验报告

    实验内容 1.使用JDK编译.运行简单的Java程序: 2.使用Eclipse 编辑.编译.运行.调试Java程序. 实验要求 1.没有Linux基础的同学建议先学习<Linux基础入门(新版) ...

  6. 2016-2017-2 20155227实验二《Java面向对象程序设计》实验报告

    2016-2017-2 20155227实验二<Java面向对象程序设计>实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉 ...

  7. Wiki版产品需求---产品需求文档到底是谁的?产品到底是谁的?

    在听了测试的一通唠叨之后,"内部实现一堆逻辑,只有一句话的需求文档","文档那么简单,我们怎么测试啊",心中突然想起来自己曾经干的一件当时觉得还不错的事情,但是 ...

  8. POI导出excel文件样式

    需求: 公司业务和银行挂钩,各种形式的数据之间交互性比较强,这就涉及到了存储形式之间的转换 比如数据库数据与excel文件之间的转换 解决: 我目前使用过的是POI转换数据库和文件之间的数据,下边上代 ...

  9. apache-kylin-2.5.2-bin-cdh57与cdh-5.13.0集群整合运用

    1.下载kylin最新版apache-kylin-2.5.2-bin-cdh57: 2.解压配置环境变量: export BASE_PATH="/opt/cloudera/parcels/C ...

  10. apache开启伪静态的方法 php篇

    打开apache的配置文件httpd.conf 找到 #LoadModule rewrite_module modules/mod_rewrite.so 把前面#去掉.没有则添加,但必选独占一行,使a ...