我有以下gulpfile.js,我通过命令行gulp消息执行:

var gulp = require('gulp');

gulp.task('message', function() {
  console.log("HTTP Server Started");
});

我得到以下错误消息:

[14:14:41] Using gulpfile ~\Documents\node\first\gulpfile.js
[14:14:41] Starting 'message'...
HTTP Server Started
[14:14:41] The following tasks did not complete: message
[14:14:41] Did you forget to signal async completion?

我在Windows 10系统上使用gulp 4。下面是gulp——version的输出:

[14:15:15] CLI version 0.4.0
[14:15:15] Local version 4.0.0-alpha.2

当前回答

我不能说我在这方面很有知识,但我也遇到过同样的问题,并且已经解决了。

解决这个问题的第七种方法是使用async函数。

编写函数时,要加上async前缀。

通过这样做,Gulp将函数包装在承诺中,任务将正常运行。

例子:

async function() {
  // do something
};

资源:

Gulp页面的最后一节:使用Async /await。 Mozilla异步函数文档。

其他回答

你需要做两件事:

在函数之前添加async。 用return开始函数。 Var gulp = require('gulp'); 饮而尽。Task ('message', async function() { 返回console.log("HTTP服务器已启动"); });

在默认函数中添加done作为参数。这样就行了。

我知道这个问题在6年前就出现了,但可能你在函数中错过了返回。 我今天早上用eslint修复了这个问题,在我的工作目录中运行“gulp lint”后,它给了我同样的消息。

例子:

function runLinter(callback)
{
  return src(['**/*.js', '!node_modules/**'])
    .pipe(eslint())
    .on('end', ()=>
    {
        callback();
    });
}

exports.lint = runLinter;

我的解决方案:把所有东西都放在async中,然后等待gulp。

async function min_css() {
    return await gulp
        .src(cssFiles, { base: "." })
        .pipe(concat(cssOutput))
        .pipe(cssmin())
        .pipe(gulp.dest("."));
}

async function min_js() {
    return await gulp
        .src(jsFiles, { base: "." })
        .pipe(concat(jsOutput))
        .pipe(uglify())
        .pipe(gulp.dest("."));  
}

const min = async () => await gulp.series(min_css, min_js);

exports.min = min;

对我来说,问题是不同的:angular -cli没有安装(我用NVM安装了一个新的Node版本,只是忘记重新安装angular cli)

你可以检查运行“ng version”。

如果你没有,运行"npm install -g @angular/cli"