2016-04-03 13 views
2

Ich versuche, eine Website meiner kleinen bussiness von Kabeln und Leitungen zu machen mit NodeJS exprimieren (EJS)wie statische Dateien mit NodeJS dient in mehrere Routing

Dateien ist wie:

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'); 

/* routes variables*/ 

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

var app = express(); 

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


app.use(logger('dev')); 
app.use(bodyParser.json()); 
app.use(bodyParser.urlencoded({ extended: false })); 
app.use(cookieParser()); 
app.use(require('less-middleware')(path.join(__dirname, 'public'))); 
app.use(express.static(path.join(__dirname, 'public'))); 
app.use(express.static('public')); 
app.use(express.static('public/stylesheets')); 
app.use(express.static('public/images')); 
app.use(express.static('public/javascripts')); 


/* routes */ 
app.use('/', routes); // index page 
app.use('/cableWires', cableWires); //cables and wires 

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; 

In Routen/cablesWires.js

var express = require('express'); 
var router = express.Router(); 

router.get('/', function(req, res, next) { 
    res.render('products_cableWires', { title: 'Umesh Electricals' }); 


}); 

router.get('/submersible_cables', function(req, res, next) { 
    res.render('submersible-cables', { title: 'Umesh Electricals' }); 
}); 


router.get('/house_wires', function(req, res, next) { 
    res.render('house-wires', { title: 'Umesh Electricals' }); 
}); 

module.exports = router; 

Als ich nach cableWires Seite gehen, alles ist in Ordnung, aber wenn ich auf house_wires Seite oder submersible_cables gehe Seite, lädt er den Inhalt der EJS-Datei aber nicht statische Dateien laden (CSS, JavaScript und Bilder)

Was den möglichen Fehler bin könnte ich

Antwort

0

sein zu tun scheint, dass, wenn Sie Antrag auf jeden Weg machen diese Datei dann von diesem URL-Pfad zu holen versucht es also - wenn Sie anrufen/route1 dann wird es die statischen Aufruf Datei vom relativen Pfad..so müssen Sie es in absoluten Pfad ändern ..
so c hange der statischen Pfad und umfassen „/“ vor dem statischen Pfad

app.use(express.static('public')); app.use(express.static('/public/stylesheets')); app.use(express.static('/public/images')); app.use(express.static('/public/javascript 

Sie uns, wenn seine Hilfe

+0

Ihre Methode wissen lassen, anstatt einen absoluten Pfad setzen, tatsächlich den Pfad zu ändern, wo Server für statische Dateien gesucht werden soll –