返回顶部
首页 > 资讯 > 前端开发 > html >gulp4中出现assert.js throw err AssertionError错误怎么办
  • 801
分享到

gulp4中出现assert.js throw err AssertionError错误怎么办

2024-04-02 19:04:59 801人浏览 安东尼
摘要

这篇文章主要介绍了gulp4中出现assert.js  throw err  AssertionError错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后

这篇文章主要介绍了gulp4中出现assert.js  throw err  AssertionError错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

前情:

  • 由于更换电脑,重装环境,在gulp的时候总是报错

assert.js:350
    throw err;
    ^
AssertionError [ERR_ASSERTION]: Task function must be specified
    at Gulp.set [as _setTask]

查了很久才发现是gulp3.9.1和4.0的差别造成的。

gup3 VS gulp4 区别

Gulp 4最大的变化就是你不能像以前那样传递一个依赖任务列表。
Gulp3,如果有一个任务A,B和C的列表,你想在一个序列中运行A,B,和C,代码如下:

gulp.task('default', ['A', 'B, 'C']);

在Gulp 4中,你不能再这样做了。你会得到以下错误:

assert.js:350
    throw err;
    ^

AssertionError [ERR_ASSERTION]: Task function must be specified
    at Gulp.set [as _setTask] (D:\python\project\前端工程化\shop\node_modules\undertaker\lib\set-task.js:1
0:3)
    at Gulp.task (D:\Python\project\前端工程化\shop\node_modules\undertaker\lib\task.js:13:8)
    at Object.<anonymous> (D:\python\project\前端工程化\shop\gulpfile.js:34:6)
    at Module._compile (internal/modules/cjs/loader.js:688:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:699:10)
    at Module.load (internal/modules/cjs/loader.js:598:32)
    at tryModuleLoad (internal/modules/cjs/loader.js:537:12)
    at Function.Module._load (internal/modules/cjs/loader.js:529:3)
    at Module.require (internal/modules/cjs/loader.js:636:17)
    at require (internal/modules/cjs/helpers.js:20:18)

不要用Gulp3的方式指定依赖任务,你需要使用gulp.series和gulp.parallel,因为gulp任务现在只有两个参数。
gulp.series:按照顺序执行
gulp.paralle:可以并行计算

gulp.task('my-tasks', gulp.series('a', 'b', 'c', function() {
  // Do something after a, b, and c are finished.
}));
gulp.task('build', gulp.parallel('styles', 'scripts', 'images', function () {
  // Build the WEBsite.
}));

或者这样

gulp.task('my-tasks', gulp.series('a', gulp.parallel('styles','scripts', 'images'), 'b', 'c', function() {
  // Do something after a, b, and c are finished.
}));

相关任务必须在被调用之前发生

在Gulp 3中,可以让你的文件引用它们之前的任务,因为一切都是默认异步执行的。现在,您需要在依赖关系在您的gulp文件中定义之后放置调用依赖项的任务。否则,你会得到这样的错误:

assert.js:85
  throw new assert.AssertionError({
  ^
AssertionError: Task never defined: serve
    at getFunction (D:\python\project\前端工程化\shop\node_modules\undertaker\lib\helpers\nORMalizeArgs.js:15:5)
    at arrayMap (D:\python\project\前端工程化\shopnode_modules\lodash.map\index.js:140:21)
    at map (D:\python\project\前端工程化\shopnode_modules\lodash.map\index.js:1836:10)
    at normalizeArgs (D:\python\project\前端工程化\shopnode_modules\undertaker\lib\helpers\normalizeArgs.js:19:10)
    at Gulp.series (D:\python\project\前端工程化\shopnode_modules\undertaker\lib\series.js:13:14)
    at Object.<anonymous> (D:\python\project\前端工程化\shop/gulpfile.js:41:27)
    at Module._compile (module.js:570:32)
    at Object.Module._extensions..js (module.js:579:10)
    at Module.load (module.js:487:32)
    at tryModuleLoad (module.js:446:12)

解决方法:使依赖任务在文件的底部。
gulp4中需要指定task结束
gulp4中,必须告诉gulp我们的task任务已经完成了。gulp3中,我们不必要这么做,因为如果没有发出异步完成信号,那么当任务返回时,gulp会认为它已经完成了,gulp4中必须明确指出任务完成了。

使用回调函数作为您的任务的第一个参数,只需在完成时调用该函数。

gulp.task('clean', function(done) {
  del(['build]);
    done();
});

告诉gulp任务完成的另一个常见方法是 返回(return) 一个流或者 Promise

gulp.task('minify:js', function() {
  return gulp.src('client*.js')
    .pipe(minify())
    .pipe(gulp.dest('build'));
});
gulp.task('message', function() {
  return new Promise(function(resolve, reject) {
    console.log("Http Server Started");
    resolve();
  });
});

浏览器同步刷新,而不是样式注入

我的Gulp 3文件没有问题,在html重建上进行刷新,并在CSS更改上进行闪电般的风格注入,但升级到Gulp 4后,浏览器现在会在CSS更改后重新加载。

  • 需要以不同的方式做三件事。首先确保您将一个文件数组传递给Browsersync构造函数

var bsConfig = {
    server: 'build',
    files: [
        'build'
    ],
    open: false,
};

gulp.task('browserSync', function() {
    bs.init(bsConfig);
});
  • 其次,如果你有任务bs.stream()结束styles,你可以删除它。

  • 第三,当你想在你的开发服务器上进行实时风格注入时,你的watch和browserSync任务需要并行运行,    而不是终止,就像这样:

gulp.task('serve', gulp.series('build', gulp.parallel('watch', 'browserSync')));

感谢你能够认真阅读完这篇文章,希望小编分享的“gulp4中出现assert.js  throw err  AssertionError错误怎么办”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网html频道,更多相关知识等着你来学习!

--结束END--

本文标题: gulp4中出现assert.js throw err AssertionError错误怎么办

本文链接: https://lsjlt.com/news/83648.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • gulp4中出现assert.js throw err AssertionError错误怎么办
    这篇文章主要介绍了gulp4中出现assert.js  throw err  AssertionError错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后...
    99+
    2024-04-02
  • navicat中出现10061错误怎么办
    小编给大家分享一下navicat中出现10061错误怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!错误10061的意思是M...
    99+
    2024-04-02
  • mysqldump中出现error1066错误怎么办
    这篇文章将为大家详细讲解有关mysqldump中出现error1066错误怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。mysqldump导出数据库报错mysqld...
    99+
    2024-04-02
  • MySQL中出现2059错误怎么办
    这篇文章给大家分享的是有关MySQL中出现2059错误怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。alter user root@localhost identified...
    99+
    2024-04-02
  • mysql中出现1053错误怎么办
    这篇文章主要介绍mysql中出现1053错误怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql错误1053的解决办法:1、打开cmd控制台,执行命令“mysqld-nt ...
    99+
    2024-04-02
  • apache中出现403错误怎么办
    小编给大家分享一下apache中出现403错误怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Apache,版本2.2.8,安装完成后,进行相关测试;配置了下...
    99+
    2023-06-10
  • oracle中出现ora-01013错误怎么办
    小编给大家分享一下oracle中出现ora-01013错误怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在测试的过程中发现...
    99+
    2024-04-02
  • ORACLE中出现ORA-28365错误怎么办
    这篇文章主要为大家展示了“ORACLE中出现ORA-28365错误怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“ORACLE中出现ORA-28365错误怎...
    99+
    2024-04-02
  • oracle中出现ORA-01102错误怎么办
    这篇文章主要介绍了oracle中出现ORA-01102错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。测试环境中oracle数据库这...
    99+
    2024-04-02
  • oracle中出现ORA-01122错误怎么办
    小编给大家分享一下oracle中出现ORA-01122错误怎么办,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!现象:在做表空间恢复演练时,遇到如下错误提示:SQL> alter da...
    99+
    2024-04-02
  • oracle中出现ORA-600错误怎么办
    这篇文章主要为大家展示了“oracle中出现ORA-600错误怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“oracle中出现ORA-600错误怎么办”这...
    99+
    2024-04-02
  • oracle中出现ORA-28000错误怎么办
    这篇文章给大家分享的是有关oracle中出现ORA-28000错误怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。    这个毛病特别...
    99+
    2024-04-02
  • oracle中出现ORA-65085错误怎么办
    这篇文章主要介绍了oracle中出现ORA-65085错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。SQL> show co...
    99+
    2024-04-02
  • oracle中出现ORA-27101错误怎么办
    这篇文章主要为大家展示了“oracle中出现ORA-27101错误怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“oracle中出现ORA-27101错误怎...
    99+
    2024-04-02
  • oracle中出现ORA-15201错误怎么办
    这篇文章主要介绍oracle中出现ORA-15201错误怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!系统环境:操作系统:    AIX5300-08Ora...
    99+
    2024-04-02
  • oracle中出现ORA-12850错误怎么办
    这篇文章给大家分享的是有关oracle中出现ORA-12850错误怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 1.问题现象报错信息如下: Thu Aug 24 1...
    99+
    2024-04-02
  • oracle中出现ORA-00845错误怎么办
    这篇文章主要介绍了oracle中出现ORA-00845错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 问题描述:调大数据库内存后...
    99+
    2024-04-02
  • oracle中出现ORA-12520错误怎么办
    这篇文章主要介绍了oracle中出现ORA-12520错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 ...
    99+
    2024-04-02
  • oracle中出现ORA-09817错误怎么办
    这篇文章主要为大家展示了“oracle中出现ORA-09817错误怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“oracle中出现ORA-09817错误怎...
    99+
    2024-04-02
  • oracle中出现ORA-01502错误怎么办
    小编给大家分享一下oracle中出现ORA-01502错误怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!第一部分: 接到开...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作