暂时不支持目录修改、创建、删除
var gulp = require('gulp');
var fs = require('fs');
var path = require('path');
var less = require('gulp-less');
var sass = require('gulp-sass');
var minifycss = require('gulp-minify-css');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var rename = require('gulp-rename');
var del = require('del');
var tinylr = require('tiny-lr');
var server = tinylr();
var port = 1234; // browser-sync
var browserSync = require('browser-sync'); // 创建多层目录
function mkdirs(dirname, mode, callback){
fs.exists(dirname, function (exists){
if(exists){
callback();
}else{
//console.log(path.dirname(dirname));
mkdirs(path.dirname(dirname), mode, function (){
fs.mkdir(dirname, mode, callback);
});
}
});
} // 拷贝文件
function copyfile(oldPath, newPath) {
console.log('复制'+oldPath+' -> '+newPath); var stat = fs.lstatSync(oldPath);
if(stat.isDirectory()) {
console.log(oldPath+'是目录');
return false;
} var readStream = fs.createReadStream(oldPath);
var writeStream = fs.createWriteStream(newPath);
readStream.pipe(writeStream);
readStream.on('end', function () {
console.log('copy end');
});
readStream.on('error', function () {
console.log('copy error');
});
} gulp.task('default', function() { }); gulp.task('css', function() {
return gulp.src('src/*.css') //压缩的文件
.pipe(gulp.dest('target/css')) //输出文件夹
.pipe(minifycss()); //执行压缩
}); // 编译Sass
gulp.task('sass', function() {
gulp.src('./src/css/*.scss')
.pipe(sass())
.pipe(rename({ suffix: '.min' }))
.pipe(minifycss())
.pipe(gulp.dest('target/css'));
}); gulp.task('js', function() {
return gulp.src('./src/js/*.js')
.pipe(gulp.dest('target/js')) //输出main.js到文件夹
.pipe(rename({suffix: '.min'})) //rename压缩后的文件名
.pipe(uglify()) //压缩
.pipe(gulp.dest('target/js')); //输出
}); gulp.task('html', function() {
return gulp.src('./src/*.php')
.pipe(gulp.dest('target/')); //输出
}); // 监听任务 运行语句 gulp watch
gulp.task('watch',function(){
server.listen(port, function(err){
if (err) {
return console.log(err);
} //拷贝修改过的文件
gulp.watch('src/**/**', function(e) {
console.log(e);
var oldPath = e.path;
var newPath = oldPath.replace('\\src\\', '\\target\\');
var newDirPathTemp = newPath.split("\\");
var currentPath = fs.realpathSync('.');
var newDirPath = [];
for(var i = 0; i < newDirPathTemp.length-1; i++) {
newDirPath[i] = newDirPathTemp[i];
}
newDirPath = newDirPath.join("\\");
newDirPath = newDirPath.replace(currentPath, '');
newDirPath = newDirPath.replace(/\\/g, "/");
newDirPath = newDirPath.replace("/", "./");
//console.log('当前路径'+newDirPath); // 修改或增加时
if('added' == e.type || 'changed' == e.type || 'renamed' == e.type) {
// 判断目录是否存在,不存在则创建
fs.exists(newDirPath, function(exists){
if(exists){
//console.log("文件夹存在");
copyfile(oldPath, newPath);
} else {
//console.log("文件夹不存在,则创建目录");
mkdirs(newDirPath); // 延时,等待目录创建完成
setTimeout(function(){
copyfile(oldPath, newPath);
}, 200);
}
});
} else if('deleted' == e.type) { //删除
fs.unlink(newPath, function(err){
console.log('删除'+newPath+err);
});
}
}); // 监听sass
gulp.watch('src/css/*.scss', function(){
gulp.run('sass');
}); // 监听js
gulp.watch('./src/js/*.js', function(){
gulp.run('js');
}); // 监听html
gulp.watch('./src/*.php', function(){
gulp.run('html');
}); }); // 实时同步到浏览器
browserSync.init(['target/css/*', 'target/js/*', 'target/*.html', 'target/*.php'], {
/* 静态服务
server: {
baseDir: "target"
}
*/ // 代理模式
proxy: "dz.com"
}); });

  

gulp监听文件变化,并拷贝到指定目录的更多相关文章

  1. gulp监听文件变化,并拷贝到指定目录(转)---参考记录

    ###暂时不支持目录修改.创建.删除.var gulp = require('gulp'); var fs = require('fs'); var path = require('path'); v ...

  2. 如何使用NodeJs来监听文件变化

    1.前言 在我们调试修改代码的时候,每修改一次代码,哪怕只是很小的修改,我们都需要手动重新build文件,然后再运行代码,看修改的效果,这样的效率特别低,对于开发者来说简直不能忍. 2.构建自动编译工 ...

  3. node.js监听文件变化

    前言 随着前端技术的飞速发展,前端开发也从原始的刀耕火种,向着工程化效率化的方向发展.在各种开发框架之外,打包编译等技术也是层出不穷,开发体验也是越来越好.例如HMR,让我们的更新可以即时可见,告别了 ...

  4. 利用WatchService监听文件变化

    在实现配置中心的多种方案中,有基于JDK7+的WatchService方法,其在单机应用中还是挺有实践的意义的. 代码如下: package com.longge.mytest; import jav ...

  5. shell遍历文件目录,监听文件变化,拼接字符串

    最近利用业余时间学习了shell 并做了个例子 实现的功能是 : 监听demo文件夹下的文件,只要新增了  .js的文件就把对应的文件名重组,拼接, 最后写入到demo.js里面. 文件结构如下 : ...

  6. gulp之sass 监听文件,自动编译

    gulpfile.js文件如下: var gulp = require('gulp'); var sass = require('gulp-sass'); gulp.task('default', f ...

  7. 玩转gulp之watch监听文件自动编译

    博客移至 https://www.dodoblog.cn/blog?id=5befc928e0feb34495b57035 我们在写页面的时候,用到sass less等css预处理器的时候,虽然写的很 ...

  8. Java NIO.2 使用Path接口来监听文件、文件夹变化

    Java7对NIO进行了大的改进,新增了许多功能: 对文件系统的访问提供了全面的支持 提供了基于异步Channel的IO 这些新增的IO功能简称为 NIO.2,依然在java.nio包下. 早期的Ja ...

  9. 【转载】java 监听文件或者文件夹变化的几种方式

    1.log4j的实现的文件内容变化监听 package com.jp.filemonitor; import org.apache.log4j.helpers.FileWatchdog; public ...

随机推荐

  1. JavaScript拼图游戏

    今天是2016年最后一天上班了.最近几天都比较休闲,有时间空闲下来写写文档之类的. 2016过得真是快.感觉没做什么就过去了.想到之前想坚持每个月写一写博客都没坚持到.希望2017年可以吧. 无聊之余 ...

  2. ittun配置和使用教程

    有好久没写博了.时间过得真快,一下子一年又过去了. 不墨迹这么多了. 作为一个前端,页面写好了少不了做测试以及给其他同事看看效果,然而公司没有测试服务器,真是悲催哦. 一直都是用ip地址看页面的.但是 ...

  3. Visor 应用之一 通过ER 设计生成数据库脚本和实体对象

    前言 Visor(http://www.visor.com.cn)   是一个基于HTML5 Canvas 开发的IDE 框架和设计开发平台,有关Visor的设计架构和技术应用,在以后的文章里会逐渐跟 ...

  4. .net 读取Excel文件报错

    错误内容 Microsoft Office Excel 不能访问文件“D:\WWWRoot\Website\Test\Excels\Test1.xls”. 可能的原因有: 1 文件名称或路径不存在. ...

  5. scanf_s 可能会出现的死循环

                                        VS2015中提供了scanf_s().在调用时,必须提供一个数字以表明最多读取多少位字符. scanf_s("%s& ...

  6. hibernate的1+n

    对数据库访问还是必须考虑性能问题的, 在设定了1 对多这种关系之后, 查询就会出现传说中的n +1 问题. 1 )1 对多,在1 方,查找得到了n 个对象, 那么又需要将n 个对象关联的集合取出,于是 ...

  7. as3延迟处理

    查找关键字“flashplayer 弹性跑道” 每当一帧即将走完,FlashPlayer就要做些总结性工作(一次性地汇总变化),把这一帧当中发生的变化拿出来展示(渲染)一下. 如果它处理的事情少,工作 ...

  8. c# 字符串操作

    一.字符串操作 //字符串转数组 string mystring="this is a string" char[] mychars=mystring.ToCharArray(); ...

  9. 几个功能强大的系统源码(机票分销、机票预订、OA、手机充值、wifi营销、网络超市、体检平台)

    1.机票分销.机票预订系统源码 2.OA系统源码 3.手机在线充值系统源码 4.wifi营销系统源码 5.网络超市系统源码 6.在线体检平台系统源码 7.违章查询与缴费系统源码 需要的同学请联系QQ: ...

  10. html5/css学习笔记

    请始终将正斜杠添加到子文件夹.假如这样书写链接:href="http://www.w3cschool.cc/html",就会向服务器产生两次 HTTP 请求.这是因为服务器会添加正 ...