2016-04-27 10 views
2

EJS、Node、およびExpress(3つすべてに新機能)を使用しようとしています。ここに私のejsファイル、私のapp.jsファイル、およびディレクトリ構造があります。物事を正しく設定する方法を理解してもらえますか?前もって感謝します。EJS、Express、Node - ロードするjsまたはcssを取得できません。

EJSファイル:

<html> 
    <head> 
    <script href="/javascripts/main.js"></script> 
    <link rel="stylesheer" href="/stylesheets/style.css" /> 
    </head> 
    <body> 
    test 
    </body> 
</html> 

app.js:

var express = require('express'); 
var path = require('path'); 
var favicon = require('serve-favicon'); 
var logger = require('morgan'); 
var cookieParser = require('cookie-parser'); 
var bodyParser = require('body-parser'); 

var routes = require('./routes/index'); 
var users = require('./routes/users'); 

var app = express(); 

// view engine setup 
app.set('views', path.join(__dirname, 'views')); 
app.set('view engine', 'ejs'); 

// uncomment after placing your favicon in /public 
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico'))); 
app.use(logger('dev')); 
app.use(bodyParser.json()); 
app.use(bodyParser.urlencoded({ extended: false })); 
app.use(cookieParser()); 
app.use(express.static(path.join(__dirname, 'public'))); 

app.use('/', routes); 
app.use('/users', users); 

// catch 404 and forward to error handler 
app.use(function(req, res, next) { 
    var err = new Error('Not Found'); 
    err.status = 404; 
    next(err); 
}); 

// error handlers 

// development error handler 
// will print stacktrace 
if (app.get('env') === 'development') { 
    app.use(function(err, req, res, next) { 
    res.status(err.status || 500); 
    res.render('error', { 
     message: err.message, 
     error: err 
    }); 
    }); 
} 

// production error handler 
// no stacktraces leaked to user 
app.use(function(err, req, res, next) { 
    res.status(err.status || 500); 
    res.render('error', { 
    message: err.message, 
    error: {} 
    }); 
}); 


module.exports = app; 

ファイル構造:

template_1 
> bin 
> node_modules 
> public 
     > images 
     > javascripts 
      | main.js 
     > stylesheets 
      | style.css 
> routes 
> views 
     | index.ejs 
| app.js 
| gulpfile.js 
| package.json 
+1

パブリックディレクトリを 'app.use(express.static( 'public'));' –

+0

OR app.use(express.static(__ dirname + '/ public /'))に変更すると、 ); –

+0

@JoshuaTerrill - この行を置き換えることを確認するには? app.use(express.static(path.join(__ dirname、 'public')));私はそれを試しましたが、それはまだ動作していません。 –

答えて

0

私は@JoshuaTerrillソリューを試してみましたそれは動作します(あなたのアプリを再起動します)。

関連する問題