2

我在 nodejs 中运行了以下基本脚本,以提供带有关联 css 样式表的 html 文件:

var http = require('http');
var fs = require('fs');
var path = require('path');

var serverPort = 8080;

var server = http.createServer(function(request, response) {

console.log('request starting ...');
var extname = path.extname(request.url);

var contentType = 'text/html';
    switch (extname) {
    case '.js':
        contentType = 'text/javascript';
        break;
    case '.css':
        contentType = 'text/css';
        break;
    }

fs.readFile('js/EmailDisplay/htm/index.html', function(error, content) {
    if (error) {
        console.log(error);
        response.writeHead(500);
        response.end();
    } else {
        console.log(contentType);
        response.writeHead(200, {'Content-Type': contentType});
        response.end(content,'utf-8');
    }
});
});

server.listen(serverPort);
console.log('Server running at localhost:' + serverPort +"/");

如果我在 Firefox 中打开文件(文件->打开文件),它会正确呈现。如果我去 localhost:8080 提供索引页面,但没有应用样式。为什么?fs.readFile 块中的 console.log 显示两个文件都在被读取。

PS - 我知道有些软件包可以让我盲目地这样做(例如“连接”),但我试图在走这条路线之前了解实际发生的情况。

4

2 回答 2

2

问题可能出在这一行:

 fs.readFile('js/EmailDisplay/htm/index.html', function(error, content) {

您正在读取并向客户端返回相同的 html 文件,即使在请求时.js也是如此。.css

您可能应该在代码中前面的开关中沿其内容类型设置文件的路径。

于 2012-09-06T14:39:01.067 回答
0

我在使用 nodejs 和 express 时遇到了同样的问题。server.js请参阅下面的示例

var express= require("express");
var app= express();
app.get("/", function(request, response) {
    response.sendFile("testing.html", {root: "."});
});
app.listen(8080);

可以通过包含以下行来添加静态内容:

app.use(express.static("foundation-5.4.6", {index: false}));

这使用express.static。就我而言,我从Foundation框架提供静态 css 和 js,但您可以轻松地将其修改为您的特定public文件夹。

于 2014-11-12T15:06:19.983 回答