我正在使用Node Boilerplate并且一切正常,直到我决定在其上创建另一个项目(在另一个目录中)。
现在,我在两个不同的文件夹中拥有完全相同的代码库(此项目)。我可以毫无问题地运行其中一个但是另一个失败了:
% node app.js
node.js:116
throw e; // process.nextTick error, or 'error' event on first tick
^
Error: Cannot find module 'connect/middleware/router'
at Function._resolveFilename (module.js:299:11)
at Function._load (module.js:245:25)
at require (module.js:327:19)
at Object.<anonymous> (/home/gotts/Sites/nodejs-uploadr/lib/express/lib/express/server.js:17:14)
at Module._compile (module.js:383:26)
at Object..js (module.js:389:10)
at Module.load (module.js:315:31)
at Function._load (module.js:276:12)
at require (module.js:327:19)
at Object.<anonymous> (/home/gotts/Sites/nodejs-uploadr/lib/express/lib/express/index.js:28:31)
这里解释了类似的问题 - https://github.com/visionmedia/express/issues/535表示问题出在connect / express的不兼容版本中。
但这怎么可能?源代码在两个文件夹中完全相同,它在一个副本中正常工作而在另一个副本中失败吗?
答案 0 :(得分:8)
这两个文件夹共享一个共同的父级吗? Node在app dir中的〜/ .node_modules和/ node_modules中查找模块。
答案 1 :(得分:7)
好的,让我回答一下我自己的问题:
对于错误信息感到抱歉 - 这两个文件夹不完全相同(我需要更好地学习unix diff)。它需要(“连接”)代码
连接到/ lib文件夹的本地检出优先,但如果它不存在 - 连接将从里卡多先前设置的〜/ .node_modules加载。
答案 2 :(得分:5)
@see node.js express module not loading properly在最后一条评论中,也许有帮助
其背后的基本思想是将模块安装在应用程序文件夹中,而不是系统级