Jade 中无法渲染 JavaScript

4

我无法从jade中调用我的script.js文件,尽管如果以内联方式插入,JavaScript可以正常渲染。这是我的第一次尝试,所以js文件只是一个警报:

alert("javascript works");

我倾向于认为我在不正确地调用脚本。目前,layout.jade 如下:

doctype 5
html
  head
    title= "LeafPress - Hot off the Presses"
    link(rel='stylesheet', href='/stylesheets/style.css')
  block scripts
    script(type='text/javascript', src='/javascripts/script.js')
  body
    block content

我尝试了许多脚本路径的排列组合(../public/javascripts/script.js; /public/javascripts/script.js; public/javascripts/script.js; javascripts/script.js; script.js),并尝试将脚本直接放在根目录和“views”目录中。

app.js:

/**
 * Module dependencies.
 */

var express = require('express')
  , routes = require('./routes/index')
  , user = require('./routes/user')
  , http = require('http')
  , path = require('path');

var app = express();

app.configure(function(){
  app.set('port', process.env.PORT || 3000);
  app.set('views', __dirname + '/views');
  app.set('view engine', 'jade');
  app.use(express.favicon());
  app.use(express.logger('dev'));
  app.use(express.bodyParser());
  app.use(express.methodOverride());
  app.use(express.cookieParser('your secret here'));
  app.use(express.session());
  app.use(app.router);
  app.use(require('stylus').middleware(__dirname + '/public'));
  app.use(express.static(path.join(__dirname, 'public')));
});

app.configure('development', function(){
  app.use(express.errorHandler());
});

app.get('/', routes.index);
app.get('/permalink', routes.permalink);
app.get('/users', user.list);

http.createServer(app).listen(app.get('port'), function(){
  console.log("Express server listening on port " + app.get('port'));
});

index.js:

/*
 * GET home page.
 */

exports.index = function(req, res){
  res.render('index', { title: 'Express' });
};

exports.permalink = function(req, res) {
  res.render('permalink', { title: 'Comments page' });
};

我的相关文件层次结构如下:

- public
  - javascripts
    - script.js
- views
  - index.jade
  - layout.jade
- routes
  - index.js

app.js

这似乎与问题相关,但并没有解决问题:在使用Express/Node.js的Jade模板中静态JavaScript未呈现

2
渲染后的HTML中的脚本标签是什么样子?另外,您的Web检查器的网络选项卡显示了什么?这些脚本是否被请求?如果是,您的节点服务器会做出什么响应? - Alex Wayne
1个回答

2
尝试完全删除此行app.use(app.router);。手动更改express中间件堆栈中路由器的位置通常会产生不良行为。除非您确信自己知道正在做什么并且预期发生什么,否则不要这样做。对于臭名昭著的cannot GET /javascripts/script.js,express记录器的输出将直接指向中间件/路由配置错误。
我猜测您的问题的markdown语法只是出了点问题,但请确保script.js文件在javascripts目录内,而不是它的同级目录。

谢谢,这使得一切都正常工作了。修复了层次结构语法。 - Henry Marshall

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接