我有一个名为的小节点脚本/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] }
(换句话说 - 它有效。)
为什么会有差异以及如何使脚本正常工作?