快速版本是最新的。
这是app.js文件,另一个app.js文件使用它:

"use strict";
var express = require('express'), engine = require('ejs-locals');
var path = require('path'), map = require('../../app').map;
var register = require('./routes/register').register;
var profile = require('./routes/profile').profile;
var login = require('./routes/login').login;

var app = module.exports = express();
app.configure(function() {
    app.engine('ejs', engine);
    app.set('views', __dirname + '/views');
    app.set('view engine', 'ejs');
    app.use('/assets', express.static(path.join(__dirname, 'assets')));
});

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

app.map = map;
app.map(app, {
    '/seller': {
        '/password': {
            get: login.forgot, // Looks in the correct place /assets/css/... etc.
            '/forgot': {
                get: login.forgot // Looks in wrong place /seller/assets/... etc.
            },
            '/reset': {
                get: login.reset
            }
        }
    }
});

当请求gethttp://localhost:3000/seller/password时,express会在正确的位置查找静态文件,即/assets/css/。
但是当请求gethttp://localhost:3000/seller/password/forgot时,express会在错误的位置查找静态文件,即/seller/assets/css,它们甚至都不存在。
这是map函数。它取自快车route-map example
function route_map(app, a, route) {
    route = route || '';
    for (var key in a) {
        switch (typeof a[key]) {
            case 'object': // { '/path': { ... }}
            app.map(app, a[key], route + key);
            break;
            case 'function': // get: function(){ ... }
            app[key](route, a[key]);
            break;
        }
    }
}

最佳答案

请求错误文件的应该是浏览器,而不是express,express是服务器。因此,您的客户端html可能是错误的,可能它试图转到../../assets/css当您的url是/seller/password/时是正确的,因为它有两个级别,您的css请求有两个向上的目录,但是,当您的url是/seller/password/forgot时,它试图向上两个级别,现在是/seller所以它在之后附加/assets/css

09-25 16:24