node.js + express + socket.io 无法将 javascript 个文件加载到 index.html
node.js + express + socket.io cannot load javascript files into index.html
我正在开发一个应用程序,服务器目前已设置好并且运行良好。
这是您访问服务器时显示的index.html:
<!doctype html>
<html>
<head>
<title>Socket.IO chat</title>
</head>
<body>
<script src="https://cdn.socket.io/socket.io-1.2.0.js"></script>
<script type="text/javascript" src="./client.js"></script>
<script type="text/javascript" src="./main.js"></script>
</body>
</html>
但是,在导入位于同一目录中的那些 javascript 文件时,我收到 404 错误 "Failed to load resource: the server responded with a status of 404 (Not Found)"。
这是我的服务器代码:
var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
app.get('/', function(req, res){
res.sendFile(__dirname+'/index.html'); // DO I NEED TO SEND THE OTHER FILES HERE ASWELL?
});
io.on('connection', function(socket){
console.log('a user connected');
socket.on('disconnect', function(){
console.log('user disconnected');
});
socket.on('chat message', function(msg){
console.log('message: ' + msg);
io.emit('chat message', msg);
});
});
http.listen(3000, function(){
console.log('listening on *:3000');
});
谢谢!
如果 HTML 文件与脚本位于同一路径,则使用 src = "main.js"
等相对路径。如果还是不行,可能是 Express 的问题。
将以下代码添加到您的 app.js
:
app.use(express.static(__dirname + '/scripts'));
并且可以从相对于 /scripts
- 的路径访问脚本,例如 main.js
来自 http://yourdomain/script.js
但不能来自 http://yourdomain/scripts/main.js
.
对不起我的英语。
我正在开发一个应用程序,服务器目前已设置好并且运行良好。
这是您访问服务器时显示的index.html:
<!doctype html>
<html>
<head>
<title>Socket.IO chat</title>
</head>
<body>
<script src="https://cdn.socket.io/socket.io-1.2.0.js"></script>
<script type="text/javascript" src="./client.js"></script>
<script type="text/javascript" src="./main.js"></script>
</body>
</html>
但是,在导入位于同一目录中的那些 javascript 文件时,我收到 404 错误 "Failed to load resource: the server responded with a status of 404 (Not Found)"。
这是我的服务器代码:
var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
app.get('/', function(req, res){
res.sendFile(__dirname+'/index.html'); // DO I NEED TO SEND THE OTHER FILES HERE ASWELL?
});
io.on('connection', function(socket){
console.log('a user connected');
socket.on('disconnect', function(){
console.log('user disconnected');
});
socket.on('chat message', function(msg){
console.log('message: ' + msg);
io.emit('chat message', msg);
});
});
http.listen(3000, function(){
console.log('listening on *:3000');
});
谢谢!
如果 HTML 文件与脚本位于同一路径,则使用 src = "main.js"
等相对路径。如果还是不行,可能是 Express 的问题。
将以下代码添加到您的 app.js
:
app.use(express.static(__dirname + '/scripts'));
并且可以从相对于 /scripts
- 的路径访问脚本,例如 main.js
来自 http://yourdomain/script.js
但不能来自 http://yourdomain/scripts/main.js
.
对不起我的英语。