带有Express Framework的NodeJS - js脚本的相对路径

时间:2015-04-16 16:04:32

标签: javascript jquery node.js express

我使用Express生成器来创建节点应用程序。目录结构如下所示:

.
├── app.js
├── bin
│   └── www
├── package.json
├── public
│   ├── images
│   ├── javascripts
│   └── stylesheets
│       └── style.css
├── node_modules
│   └── jquery
│       └── dist
|            |___jquery.min.js
├── routes
│   ├── index.js
│   └── users.js
└── views
    ├── error.jade
    ├── index.jade
    └── layout.jade

在我的index.jade文件中,我尝试从node_modules重用jquery.min.js,而不是使用url到web源:

    doctype html
html
 head
 link(rel='stylesheet', href= '/stylesheets/style_monit.css')

body
 #container
  .row
   .col-sm-4(style='background-color:lavender;') .col-sm-4
   .col-sm-4(style='background-color:lavenderblush;') .col-sm-4     
   .col-sm-4(style='background-color:lavender;') .col-sm-4
   .col-md-4
    textarea#inData.form-control(style='background:#222; color:#00ff00;', rows='8')
 script(type='text/javascript' src='../node_modules/jquery/dist/jquery.min.js')

css文件加载很棒,但在Chrome控制台中我有错误

获取http://localhost:3000/node_modules/jquery/dist/jquery.min.js 没发现

1 个答案:

答案 0 :(得分:1)

我认为问题是node_modules目录是私有的,不应该暴露给客户端。只能提供公共目录中的静态文件。有关详细信息,请参阅this Stack Overflow answer