从GitHub下载模块并按照说明进行构建后,我尝试使用以下方法将其拉入现有项目:

> npm install ../faye

这似乎起到了作用:

> npm list
/home/dave/src/server
└─┬ faye@0.7.1
  ├── cookiejar@1.3.0
  ├── hiredis@0.1.13
  └── redis@0.7.1

但是Node.js找不到模块:

> node app.js
node.js:201
        throw e; // process.nextTick error, or 'error' event on first tick
              ^
Error: Cannot find module 'faye'
    at Function._resolveFilename (module.js:334:11)
    at Function._load (module.js:279:25)
    at Module.require (module.js:357:17)
    at require (module.js:368:17)
    at Object.<anonymous> (/home/dave/src/server/app.js:2:12)
    at Module._compile (module.js:432:26)
    at Object..js (module.js:450:10)
    at Module.load (module.js:351:31)
    at Function._load (module.js:310:12)
    at Array.0 (module.js:470:10)

我真的很想了解这里发生了什么,但我有点不知所措,不知道下一步该去哪里。有什么建议吗?


当前回答

如果您需要的模块的package.json中缺少或不正确的主字段,则可能会遇到此错误。虽然模块本身已安装,但npm/node必须使用单个.js文件作为模块的入口点。如果主字段不在,则默认在模块的文件夹中查找index.js。如果模块的主文件不名为index.js,它将无法要求它。

在将基于浏览器的模块转换为CommonJS必需模块时发现;browserify并不关心缺少的主字段,因此错误没有被注意到。

其他回答

一种罕见但也可能的情况是模块名称中的拼写错误。执行节点时,我错过了文件名中的“s”。\util.js,它应该是node。\utils.js,并且在这个问题的所有答案中没有找到任何解决方案,直到我发现即使我删除了所有内容,也无法运行该文件!

如果使用nvm,请检查绑定到其他库的现有node_module是否编译为正确的node.js版本。

我也犯了同样的错误。原因如下:我们使用nvm是因为我们在一台服务器上运行两个应用程序,一个需要Node.js 5.6,因为它使用Node gd(目前不在Node.js 6上运行),另一个需要Node.js 6。Node.js 6是apt-get安装。

我们还使用pm2工具进行部署。

因此,默认设置是当nvm未生效时pm2进程启动,因此它使用Node.js(版本6)的apt-get安装。因此,主pm2守护进程从Node.js 6开始。如果我在fork模式下运行应用程序,它们将在单独的进程中启动,并且nvm设置生效。当我以集群模式运行应用程序时,它们继承了非nvm环境。

因此,当我尝试切换到集群模式时,应用程序未能启动,因为为5.6编译的绑定失败,并显示此消息。

我通过在nvm设置生效时重新启动pm2解决了这个问题。此外,还应修复启动脚本。

使用npm install仅将模块安装到当前目录中(位于名为node_modules的子目录中)。app.js是否位于home/dave/src/server/下?如果没有,并且您想从任何目录中使用该模块,则需要使用npm install-g全局安装该模块。

我通常在本地安装大多数软件包,以便将它们与我的项目代码一起签入。

更新(8/2019):

现在,您可以使用package-lock.json文件,该文件在npm修改node_modules目录时自动生成。因此,您可以省去签入包,因为package-lock.json跟踪您当前使用的node_module的确切版本。要从package-lock.json而不是package.json安装包,请使用命令npmci。

更新(2016年3月):

我的回答遭到了很多批评,特别是我检查了我的代码所依赖的包。几天前,有人发布了他们所有的包(https://kodfabrik.com/journal/i-ve-just-liberated-my-modules)这打破了React、Babel和其他一切。希望现在很清楚,如果你有生产代码,你不能依赖NPM来维护你的依赖关系。

我昨天经历了这个错误。我花了一段时间才意识到package.json中的主条目指向了我移动的文件。一旦我更新,错误消失了,包工作了。

检查环境变量NODE_PATH是否设置正确并指向NODE_modules路径。nodejs使用此变量搜索库