4

我尝试了本教程来基本设置我的 gulp 项目并激活更少的处理和观看。有用。现在我想全局安装这些模块,以便从机器上的每一个地方访问它们,而不是为每个项目安装它们:

npm install --global gulp-less
npm install --global gulp-watch
npm install --global gulp-autoprefixer
npm install --global gulp-plumber

现在我想在我的项目文件夹中运行 gulp,但是 gulp 找不到全局安装的模块:

$ cd /my/project
$ gulp
module.js:327
    throw err;
    ^

Error: Cannot find module 'gulp-less'
    at Function.Module._resolveFilename (module.js:325:15)
    at Function.Module._load (module.js:276:25)
    at Module.require (module.js:353:17)
    at require (internal/module.js:12:17)
    at Object.<anonymous> (/root/temp/gulptest/gulpfile.js:9:12)
    at Module._compile (module.js:409:26)
    at Object.Module._extensions..js (module.js:416:10)
    at Module.load (module.js:343:32)
    at Function.Module._load (module.js:300:12)
    at Module.require (module.js:353:17)
    at require (internal/module.js:12:17)

如何让它工作并使用全局 gulp 模块?

4

3 回答 3

9

解决方案是npm-link。我必须将我所有的本地包链接到全球同行:

npm link gulp
npm link gulp-less
npm link gulp-watch
npm link gulp-autoprefixer
npm link gulp-plumber
npm link path

现在它起作用了。

一些 StackOverflow 帖子与此主题相关:

于 2016-02-22T12:31:47.123 回答
1

1、全局安装gulp:

如果你之前已经全局安装了一个 gulp 版本,请运行npm rm --global gulp 以确保你的旧版本不会与 gulp-cli 冲突。

$ npm install --global gulp-cli

2.在你的项目devDependencies中安装gulp:

$ npm install --save-dev gulp

阅读更多... https://github.com/gulpjs/gulp/blob/master/docs/getting-started.md

于 2016-02-22T12:20:40.213 回答
0

对于它的价值,我通过将这一行放在我的 gulpfile.js 的顶部解决了这个问题

module.paths = module.paths.concat(module.parent.paths);

我的父模块知道我的 npm 全局目录,但是在运行 gulpfile.js 时,似乎创建了一个不知道的子模块。相反,模块路径仅与运行项目的当前目录相关,然后每个先前的目录都与我的驱动器的根目录相关。

于 2018-06-14T15:33:29.970 回答