Using gulp.watch throws "TypeError: Object #<Object> has no method 'watch'"
Using gulp.watch throws "TypeError: Object #<Object> has no method '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)
据我了解,watch 是 built-in function in gulp so what am I doing wrong here? The only other solutions to this dilemma I've seen is Linux specific (and presumable so is the cause for the problem). It is described in this SO-thread,但我正在使用 Windows,我看不出这个问题可能出现在 Windows 环境中。
此外,我查看了Gulp index.js-文件用于项目安装,它确实包含手表原型,但问题似乎(根据错误消息)来自监视功能的最后一行:
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 在这种情况下是一个包含 vinyl-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']);
感谢@ezrepotein 和@entre 帮助我。
解决方案很简单,就是重新安装node,然后卸载并重新安装项目中的所有gulp组件。
之后它运行良好,所以在安装节点或 gulp 组件的过程中肯定出了问题。
所以我在 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)
据我了解,watch 是 built-in function in gulp so what am I doing wrong here? The only other solutions to this dilemma I've seen is Linux specific (and presumable so is the cause for the problem). It is described in this SO-thread,但我正在使用 Windows,我看不出这个问题可能出现在 Windows 环境中。
此外,我查看了Gulp index.js-文件用于项目安装,它确实包含手表原型,但问题似乎(根据错误消息)来自监视功能的最后一行:
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 在这种情况下是一个包含 vinyl-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']);
感谢@ezrepotein 和@entre 帮助我。
解决方案很简单,就是重新安装node,然后卸载并重新安装项目中的所有gulp组件。 之后它运行良好,所以在安装节点或 gulp 组件的过程中肯定出了问题。