In this example,它声明您可以使用Gulp-Plumber和Gulp-Notify在每次出现错误时显示消息和声音。 Gulp-Plumber将确保Gulp手表继续运行。
然而,当我尝试它时,我继续收到此错误消息,导致Gulp停止:
events.js:72
throw er; // Unhandled 'error' event
这是我的代码:
var gulp = require('gulp'),
sass = require('gulp-ruby-sass'),
jshint = require('gulp-jshint'),
uglify = require('gulp-uglify'),
rename = require('gulp-rename'),
concat = require('gulp-concat'),
notify = require('gulp-notify'),
plumber = require('gulp-plumber'),
var onError = function(err) {
notify.onError({
title: "Gulp",
subtitle: "Failure!",
message: "Error: <%= error.message %>",
sound: "Beep"
})(err);
this.emit('end');
};
//Scripts Task
gulp.task('scripts', function() {
gulp.src('frontend/build/js/*.js')
.pipe(jshint('.jshintrc'))
.pipe(jshint.reporter('default'))
.pipe(concat('main.js'))
.pipe(gulp.dest('frontend/dist/js'))
.pipe(rename({suffix: '.min'}))
.pipe(uglify())
.pipe(gulp.dest('frontend/dist/scripts'))
.pipe(notify({
sound: "Frog"
}));
});
//Styles Task
gulp.task('styles', function() {
return sass('frontend/build/scss/', {style: 'expanded'})
.pipe(plumber({errorHandler: onError}))
.pipe(gulp.dest('frontend/dist/css/'))
.pipe(rename({suffix: '.min'}))
.pipe(gulp.dest('dist/styles'))
.pipe(notify({ // Add gulpif here
sound: "Pop"
}));
});
我的代码和示例之间的唯一区别是我将onError作为全局函数移动,因此它可以在脚本和样式任务中使用。但是,即使我将其移回样式函数内部,也会出现相同的错误消息。
(我发布的代码是缩写的,可以找到完整的代码here)
此外,有没有办法隐藏成功通知消息,所以我只是得到声音?谢谢!
答案 0 :(得分:0)
你现在可能已经想到了这一点,但是在你的完整代码中,onError函数的作用域是你的样式任务,你也没有在你的脚本任务的任何地方输入管道工。