インラインで挿入するとjavascriptは完全に正常にレンダリングされますが、jade内からscript.jsファイルを呼び出すことができません。これは私の最初の試みなので、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 )、およびスクリプトをルートおよび'ビュー'ディレクトリに直接配置してみます。
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
これは関連しているように見えましたが、問題は修正されませんでした:静的javascriptがjadeでレンダリングされない(express / node.jsを使用)