gulp: Did you forget to signal async completion? 解决方案

背景

【精选秒杀】热卖云产品限量抢,云服务器20元/月起,服务稳定,价格更优

学习gulp的前端自动化构建,按照示例代码,跑了一个简单的task,控制台打出如下提示:

The following tasks did not complete: testGulp 
Did you forget to signal async completion?

查阅Stack Overflow,表示有五种解决办法,在这里提供一种更简单的改法。

问题重现

原代码:

const gulp = require('gulp');
gulp.task('testGulp', () => {
    console.log('Hello World!');
});

控制台报错:

The following tasks did not complete: testGulp
Did you forget to signal async completion?

解决方法,使用 async 和 await。

修改后代码

const gulp = require('gulp');
gulp.task('testGulp', async() => {
   await console.log('Hello World!');
});

控制台输出正常

[13:18:37] Starting 'testGulp'...
Hello World!
[13:18:37] Finished 'testGulp' after 2.77 ms

附官方方法

在不使用文件流的情况下,向task的函数里传入一个名叫done的回调函数,以结束task,如下代码所示:

gulp.task('testGulp', done => {
  console.log('Hello World!');
  done();
});

done回调函数的作用是在task完成时通知Gulp(而不是返回一个流),而task里的所有其他功能都纯粹依赖Node来实现。

posted @   不知名也  阅读(1779)  评论(0编辑  收藏  举报
编辑推荐:
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· .NET 适配 HarmonyOS 进展
· .NET 进程 stackoverflow异常后,还可以接收 TCP 连接请求吗?
阅读排行:
· 本地部署 DeepSeek:小白也能轻松搞定!
· 如何给本地部署的DeepSeek投喂数据,让他更懂你
· 在缓慢中沉淀,在挑战中重生!2024个人总结!
· 大人,时代变了! 赶快把自有业务的本地AI“模型”训练起来!
· 从 Windows Forms 到微服务的经验教训
友情链接:alltool.top
点击右上角即可分享
微信分享提示