首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Socket.io发出欢迎使用socket.io的消息

Socket.io发出欢迎使用socket.io的消息
EN

Stack Overflow用户
提问于 2013-06-05 20:16:44
回答 1查看 2.2K关注 0票数 1

这是我的服务器

代码语言:javascript
复制
var io = require('socket.io').listen(80);

io.sockets.on('connection', function (socket) {
  socket.emit('news', { hello: 'world' });
  socket.on('my other event', function (data) {
    console.log(data);
  });
});

这是我的客户端index.html

代码语言:javascript
复制
<script src="/socket.io/socket.io.js"></script>
<script>
  var socket = io.connect('http://localhost:80');
  socket.on('news', function (data) {
    console.log(data);
    socket.emit('my other event', { my: 'data' });
  });
</script>

以下是我的命令

代码语言:javascript
复制
node server.js

在浏览器上,我点击了URL localhost:80/index.html

点击上面的网址后,我收到了欢迎使用socket.io的信息。

我使用的是nodeJS v0.10.9

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-06-05 21:09:54

socket.io提供的是socket.io服务器,而不是web服务器。所以socket.io上下文中的index.html并不存在。

相反,您可以使用Express来提供一个基本的web服务器,并结合socket.io来提供消息:

代码语言:javascript
复制
// server.js
var express = require('express');
var app     = express();
var server  = require('http').createServer(app);
var io      = require('socket.io').listen(server);

io.sockets.on('connection', function (socket) {
  socket.emit('news', { hello: 'world' });
  socket.on('my other event', function (data) {
    console.log(data);
  });
});

app.use(express.static(__dirname + '/public'));

server.listen(80);
代码语言:javascript
复制
// ./public/index.html
<!doctype html>
<html>
  <head>
    <script src="/socket.io/socket.io.js"></script>
    <script>
      var socket = io.connect(); // let socket.io autodiscover the server
      socket.on('news', function (data) {
        console.log(data);
        socket.emit('my other event', { my: 'data' });
      });
    </script>
  </head>
  <body>
    <h1>Hello World</h1>
  </body>
</html>
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16939755

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档