首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >当使用npm链接时,如何修复"Task is not in your gulpfile“错误?

当使用npm链接时,如何修复"Task is not in your gulpfile“错误?
EN

Stack Overflow用户
提问于 2015-03-11 03:21:37
回答 2查看 47K关注 0票数 13

我们有一堆共享通用gulp逻辑的应用程序,所以我们做了一个包含一堆自定义任务的gulp插件。

然而,我们希望避免为我们开发的每个应用程序安装gulp+our插件(以及半个互联网)。

理想情况下,我想做的是:

代码语言:javascript
代码运行次数:0
运行
复制
npm install -g gulp
npm install -g <our gulp plugin>

然后对于每个应用程序,我们只需执行以下操作:

代码语言:javascript
代码运行次数:0
运行
复制
npm link gulp
npm link <our gulp plugin>

虽然这是有效的,但问题是gulp不再识别我们自定义的任何gulp任务。我运行的任何gulp命令都会导致:

代码语言:javascript
代码运行次数:0
运行
复制
[15:16:51] Using gulpfile /workspace/my-app/gulpfile.js
[15:16:51] Task 'dev' is not in your gulpfile
[15:16:51] Please check the documentation for proper gulpfile formatting

“dev”任务在我的gulp插件中,为什么它找不到呢?我的gulpfile.js只有这个:

代码语言:javascript
代码运行次数:0
运行
复制
var gulp = require('gulp');
var mygulpplugin = require('mygulpplugin');

当gulp +插件在本地安装时,完全相同的过程也适用。你知道为什么吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-03-17 23:39:29

我想通了。在我的模块底部添加了下面这一行:

代码语言:javascript
代码运行次数:0
运行
复制
module.exports = gulp;

我在每个模块中的gulpfile看起来像这样:

代码语言:javascript
代码运行次数:0
运行
复制
var gulp = require('gulp'); 
var mygulpplugin = require('mygulpplugin');
gulp.tasks = mygulpplugin.tasks;
票数 7
EN

Stack Overflow用户

发布于 2015-10-21 20:53:30

除了被接受的答案,你也可以按照当时流行的方式来做这件事,在这种情况下,你可以向插件中注入大量的饮料:

插件中的将所有内容包装为:

代码语言:javascript
代码运行次数:0
运行
复制
module.exports = function(gulp) {
    gulp.task('foo', function () {
        ...
    })
    ...
}

并从插件文件中删除require('gulp')

在依赖于插件的 that文件中,您可以执行以下操作:

代码语言:javascript
代码运行次数:0
运行
复制
var gulp = require('gulp');
require('my-gulp-plugin')(gulp)

这样的话

  • 您可以在主less文件中有多个插件,因为您不会覆盖npm install)

也不必在每个插件中声明package.json依赖项(对于gulpfile来说,工作更少

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28972330

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档