如何使用全局安装的gulp模块?

时间:2016-02-18 11:46:20

标签: npm gulp npm-install gulp-less

我尝试this tutorial基本上设置了我的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模块?

3 个答案:

答案 0 :(得分:8)

解决方案是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发布到此主题:

答案 1 :(得分:0)

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

答案 2 :(得分:0)

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

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

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