Использование gulp.watch выдает: "TypeError: Object #<Object> не имеет метода" watch ""

Итак, я добавил задачу наблюдения в свой gulpfile.js, которая выглядит так:

gulp.task('watch', function(){

    gulp.watch('src/style/*.less', ['css']);
});

но когда я его запускаю (gulp watch) Я получаю следующую ошибку в моем лице:

PS C:\Projects\web\basic> gulp watch
[21:28:42] Using gulpfile C:\Projects\web\basic\gulpfile.js
[21:28:42] Starting 'watch'...
[21:28:42] 'watch' errored after 226 μs
[21:28:42] TypeError: Object #<Object> has no method 'watch'
    at Gulp.watch (C:\Projects\web\basic\node_modules\gulp\index.js:40:14)
    at Gulp.<anonymous> (C:\Projects\web\basic\gulpfile.js:37:7)
    at module.exports (C:\Projects\web\basic\node_modules\gulp\node_modules\orchestrator\lib\runTask.js:34:7)
    at Gulp.Orchestrator._runTask (C:\Projects\web\basic\node_modules\gulp\node_modules\orchestrator\index.js:273:3)
    at Gulp.Orchestrator._runStep (C:\Projects\web\basic\node_modules\gulp\node_modules\orchestrator\index.js:214:10)
    at Gulp.Orchestrator.start (C:\Projects\web\basic\node_modules\gulp\node_modules\orchestrator\index.js:134:8)
    at C:\Users\Magnus\AppData\Roaming\npm\node_modules\gulp\bin\gulp.js:129:20
    at process._tickCallback (node.js:415:13)
    at Function.Module.runMain (module.js:499:11)
    at startup (node.js:119:16)

Как я понял, часы - это встроенная функция в gulp, так что я тут делаю не так? Единственные другие решения этой дилеммы, которые я видел, являются специфичными для Linux (и, вероятно, причина проблемы). Это описано в этом SO-потоке, но я использую Windows, и я не вижу, как эта проблема может проявляться в среде Windows.

Кроме того, я просмотрел файл Gulp index.js для установки проекта, и он содержит прототип watch, но проблемы (в соответствии с сообщением об ошибке), похоже, связаны с последней строкой в ​​функции watch:

Gulp.prototype.watch = function(glob, opt, fn) {
  if (typeof opt === 'function' || Array.isArray(opt)) {
    fn = opt;
    opt = null;
  }

  // Array of tasks given
  if (Array.isArray(fn)) {
    return vfs.watch(glob, opt, function() {
      this.start.apply(this, fn);
    }.bind(this));
  }

  return vfs.watch(glob, opt, fn);
};

Это return vfs.watch(glob, opt, fn);-линии, которая вызывает сбой (это строка 40). В этом случае vfs - это переменная, которая содержит винил-fs и выглядит так:

var vfs = require('vinyl-fs');

Но даже после ручной установки, как в моем проекте, так и в глобальном масштабе, он все равно не работает. Кто-нибудь, кто знает, что может быть причиной этого сбоя?

РЕДАКТИРОВАТЬ: полный gulpfile.js:

var gulp = require('gulp'),
    less = require('gulp-less'),
    concat = require('gulp-concat'),
    uglify = require('gulp-uglify');

var cssPath = 'src/style/*.less';
var jsPath = 'src/js/*.js';
var htmlPath = 'src/index.htm';
var assetPath = 'src/assets/*';

gulp.task('css', function() {
    return gulp.src(cssPath)    //Get all less files from src/style/
        .pipe(less())                   //Pass them on to less          
        .pipe(concat('style.css'))      //Concat all files to one big style.css-file
        .pipe(gulp.dest('dist/style'))  //Pass the less result to gulp so it can be moved to dist/css
});

gulp.task('js', function(){
    return gulp.src(jsPath) //Get all the javascript files from src/js/
        .pipe(uglify())             //Pass them on to uglify
        .pipe(concat('all.js'))     //Concat all the files into one javascript file
        .pipe(gulp.dest('dist/js')) //Pass the result to gulp so it can be moved to dist/js
});

gulp.task('html', function(){
    return gulp.src(htmlPath)
        .pipe(gulp.dest('dist'))
});

gulp.task('assets', function(){
    return gulp.src(assetPath)
        .pipe(gulp.dest('dist/assets'))
});

gulp.task('watch', function(){

    gulp.watch(cssPath, ['css']);
    gulp.watch(jsPath, ['js']);
    gulp.watch(htmlPath, ['html']);
    gulp.watch(assetPath, ['assets']);
});

gulp.task('default', ['css', 'js', 'html', 'assets']);

1 ответ

Решение

Спасибо @ezrepotein и @entre за помощь.

Решение было просто переустановить узел, а затем удалить и переустановить все компоненты gulp в проекте. После этого все получилось, поэтому что-то пошло не так во время установки узла или компонентов gulp.

Другие вопросы по тегам