关于gulp任务报错处理

一、关于报错情景

  gulp进入到任务流的时候如果出现错误的话,一般来说进程会自动挂掉,要重新启动任务才能继续。由此,导致如果任务出错的话就很麻烦。所以gulp提供了监听error进行错误处理的函数。

二、关于错误处理,直接上代码

//压缩html等操作但我这里因为是测试,所以只是简单的复制没有做处理
gulp.task("html",function(){
    return gulp.src("app/**/*.html")
    .pipe(gulp.dest("app"))
    .on("error",function(err){
        console.log('Less Error!', err.message);
        this.emit('end');
    })
    .pipe(webServer.reload())
})

三、重点

  如上所示:gulp提供一个on("error",callback)抓取任务报错,并且。通过回调可打印出error对象。

  这里有个非常重要的坑:this.emit(‘end’),之前看了很多博文里都没有这一步的处理,但是我没有这一步处理的时候虽然watch进程不会挂了,但是html文件发 生变化时却不会自动编译了。所以要加上这个。有很多博文写了this.end();但至少我试了是没什么用的;

四、错误处理插件

  1、gulp错误处理插件还是比较多的,最常用的就是gulp-plumber;参考:https://www.cnblogs.com/liangcheng11/p/6894943.html

    2、但是个人觉得还不如自定义一个errorhandler函数。如下:

function handler (err){
    console.log('Less Error!', err.message);
    this.emit('end');
}
//压缩html等操作但我这里因为是测试,所以只是简单的复制没有做处理
gulp.task("html",function(){
    return gulp.src("app/**/*.html")
    .pipe(gulp.dest("app"))
    .on("error",handler)
    .pipe(webServer.reload())
})
原文地址:https://www.cnblogs.com/helloNico/p/10571872.html