zoukankan      html  css  js  c++  java
  • 关于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())
    })
  • 相关阅读:
    TZOJ 4085 Drainage Ditches(最大流)
    [国家集训队2]Tree I
    [USACO17DEC]Push a Box
    专题总结(图论)
    专题总结(分块)
    [noi.ac_D1T2]sort
    [Poi2004]SZN
    [HEOI2016/TJOI2016]求和
    [CF528D]Fuzzy Search
    [bzoj5093]图的价值
  • 原文地址:https://www.cnblogs.com/helloNico/p/10571872.html
Copyright © 2011-2022 走看看