> 백엔드 개발 > PHP 튜토리얼 > javascript - nodejs监听房间问题

javascript - nodejs监听房间问题

WBOY
풀어 주다: 2016-06-06 20:17:51
원래의
1548명이 탐색했습니다.

1.app.js

<code>
var app = require('express')();
var server = require('http').Server(app);
var io = require('socket.io')(server);
var http = require('http');

// 监听端口
server.listen(8080);

app.get('/test', function(req, res) {
    var id = req.query.id;
    var room = '/'+id;
    io.of(room).emit('message', {flag: 'refresh'});
    res.send(id);
});
</code>
로그인 후 복사
로그인 후 복사

2.index.html


<code>var id = 1;   //id是变量,由控制器模板赋值来的。为了简化程序我先给一个固定的值
var ws = io.connect('http://192.168.0.30:8888/'+id);
ws.on('message', function(obj){
    console.log(obj);
});</code>
로그인 후 복사
로그인 후 복사

首先我打开浏览器新建一个窗口访问http://192.168.0.30:8888/test?id=1,然后打开index.html按下F12,控制台没有东西输出。然后我重新刷新index.html,再次访问http://192.168.0.30:8888/test?id=1时,控制台就有东西了输出了。以后每次访问http://192.168.0.30:8888/test?id=1,index.html的控制台都有东西输出。觉得很奇怪。

请问为什么第一次访问index.html的时候控制台为啥没东西输出?问题可能描述的不清楚,请大神们帮忙解答下。在不知道id是什么值得情况下,要怎么实现这个功能?

回复内容:

1.app.js

<code>
var app = require('express')();
var server = require('http').Server(app);
var io = require('socket.io')(server);
var http = require('http');

// 监听端口
server.listen(8080);

app.get('/test', function(req, res) {
    var id = req.query.id;
    var room = '/'+id;
    io.of(room).emit('message', {flag: 'refresh'});
    res.send(id);
});
</code>
로그인 후 복사
로그인 후 복사

2.index.html


<code>var id = 1;   //id是变量,由控制器模板赋值来的。为了简化程序我先给一个固定的值
var ws = io.connect('http://192.168.0.30:8888/'+id);
ws.on('message', function(obj){
    console.log(obj);
});</code>
로그인 후 복사
로그인 후 복사

首先我打开浏览器新建一个窗口访问http://192.168.0.30:8888/test?id=1,然后打开index.html按下F12,控制台没有东西输出。然后我重新刷新index.html,再次访问http://192.168.0.30:8888/test?id=1时,控制台就有东西了输出了。以后每次访问http://192.168.0.30:8888/test?id=1,index.html的控制台都有东西输出。觉得很奇怪。

请问为什么第一次访问index.html的时候控制台为啥没东西输出?问题可能描述的不清楚,请大神们帮忙解答下。在不知道id是什么值得情况下,要怎么实现这个功能?

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿