node.js require在脚本中不起作用?

时间:2013-11-01 14:16:19

标签: javascript node.js

我有一个名为/tmp/test.js的小节点脚本,其中包含:

console.log(require("w3cjs"));

如果我从命令提示符执行此操作:

nvm use v0.10.21
node /tmp/test.js

我得到了这个输出:

module.js:340
    throw err;
      ^
Error: Cannot find module 'w3cjs'
    at Function.Module._resolveFilename (module.js:338:15)
    at Function.Module._load (module.js:280:25)
    at Module.require (module.js:364:17)
    at require (module.js:380:17)
    at Object.<anonymous> (/tmp/test.js:1:75)
    at Module._compile (module.js:456:26)
    at Object.Module._extensions..js (module.js:474:10)
    at Module.load (module.js:356:32)
    at Function.Module._load (module.js:312:12)
    at Function.Module.runMain (module.js:497:10)

但如果我这样做:

node -e $(cat /tmp/test.js)

我得到了这个输出:

{ validate: [Function: validate],
  setW3cCheckUrl: [Function: setW3cCheckUrl],
  w3cjs: [Circular] }

(换句话说 - 它有效。)

为什么差异以及如何使脚本有效?

1 个答案:

答案 0 :(得分:8)

当您在其他目录中运行脚本时,Node会在该脚本目录的node_modules文件夹中查找本地模块。

假设您的shell的工作目录当前为/projects/foo。当您运行node /tmp/test.js时,Node会在/tmp/node_modules中查找模块,而不是/projects/foo/node_modules中的模块。

但是,如果您没有运行脚本文件,而是在-e的命令行上运行一些文本,那么Node将检查shell当前工作目录中的本地模块文件夹,即{{1 }}

您的工作目录中似乎已安装/projects/foo/node_modules,但w3cjs未安装/tmp。您应该将其安装在那里,或install the module globally with npm's -g option