- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
每次客户端连接到我的 Nodejs 服务器时,我的服务器都会崩溃并出现错误“RangeError:超出最大调用堆栈大小”。我相信我一定在某个地方遇到了递归问题,但它却回避了我。
我的服务器:
require('monitor').start();
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');
});
var allClients = [];
io.on('connection', function(socket){
console.log('user joined: ' + socket.request.connection.remoteAddress + ':' + socket.request.connection.remotePort);
socket.address = socket.request.connection.remoteAddress;
socket.port = socket.request.connection.remotePort;
socket.name = '';
socket.xPos = 0;
socket.yPos = 0;
//io.emit('new user', socket.address + '_' + socket.port);
// Send current client list to new connection
socket.emit('client list', allClients);
// Only send 'new user' event to previously connected clients, not the new client.
var i = 0;
for(i=0;i<allClients.length;i++){
allClients[i].emit('new user', socket.address + '_' + socket.port);
}
// Push new socket into the client array after the array has been sent to all other users
allClients.push(socket);
socket.on('chat message', function(msg){
io.emit('chat message', socket.address + ':' + socket.port + ": " + socket.name + ' says: ' + msg);
console.log(socket.address + ":" + socket.port + ": " + socket.name + ' says: ' + msg);
});
socket.on('set_name', function(msg){
//io.emit('chat message', socket.address + ':' + socket.port + ': ' + msg);
socket.name = msg;
console.log(socket.address + ":" + socket.port + ' set name to: ' + msg);
});
socket.on('xPosUpdate', function(msg){
//io.emit('chat message', socket.address + ':' + socket.port + ': ' + msg);
console.log(socket.address + ":" + socket.port + ' set xPos to: ' + msg);
});
socket.on('yPosUpdate', function(msg){
//io.emit('chat message', socket.address + ':' + socket.port + ': ' + msg);
console.log(socket.address + ":" + socket.port + ' set yPos to: ' + msg);
});
socket.on('disconnect', function() {
io.emit('user disconnect', socket.address + '_' + socket.port);
io.emit('chat message', socket.address + ':' + socket.port + ": " + socket.name + ' disconnected.');
console.log('Got disconnect!');
socket = null;
var i = allClients.indexOf(socket);
allClients.splice(i, 1);
});
});
http.listen(3000, function(){
console.log('listening on *:3000');
});
然后在客户端处理套接字:
var users = [];
$('#chatInput').submit(function(){
socket.emit('chat message', $('#m').val());
$('#m').val('');
return false;
});
$('#nameInput').submit(function(){
socket.emit('set_name', $('#n').val());
$('#n').val('');
return false;
});
socket.on('client list', function(msg){
$('#messages').append($('<li>').text('Processing client list...'));
var i = 0;
for(i=0;i<msg.length;i++){
$('#messages').append($('<li>').text('Client ' + i + ': ' + msg[i].address + ':' + msg[i].port + ', Name: ' + msg[i].name));
}
});
socket.on('chat message', function(msg){
$('#messages').append($('<li>').text(msg));
});
socket.on('user disconnect', function(msg){
users[msg].unset();
});
socket.on('new user', function(msg){
users[msg] = [];
users[msg].xPos = 0;
users[msg].yPos = 0;
$('#messages').append($('<li>').text(msg));
});
最佳答案
感谢您的回复。
经过一些实验,我意识到由于我尝试在服务器上的以下行中发出的数据量而触发了溢出错误:
socket.emit('client list', allClients);
当新用户连接时,我会将整个连接对象推送到“allClients”数组中。连接对象中包含的数据量太大,无法通过 socket.emit 发送,并导致 RangeError。
我必须简化发送给每个新客户端的客户端列表数据,以避免这种情况......“堆栈溢出”......:)
关于javascript - 套接字IO : RangeError: Maximum call stack size exceeded,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39917706/
我使用下拉菜单提供一些不同的链接,但我希望这些链接在同一选项卡中打开,而不是在新选项卡中打开。这是我找到的代码,但我对 Javascript 非常缺乏知识 var urlmenu = docume
我对 javascript 不太了解。但我需要一个垂直菜单上的下拉菜单,它是纯 JavaScript,所以我从 W3 复制/粘贴脚本:https://www.w3schools.com/howto/t
我已经坐了 4 个小时,试图让我的导航显示下 zipper 接垂直,但它继续水平显示它们。我无法弄清楚为什么会发生这种情况或如何解决它。 如果有人能告诉我我做错了什么,我将不胜感激。我有一个潜移默化的
我正在尝试创建选项卡式 Accordion 样式下拉菜单。我使用 jQuery 有一段时间了,但无法使事件状态达到 100%。 我很确定这是我搞砸的 JS。 $('.service-button').
对于那些从未访问过 Dropbox 的人,这里是链接 https://www.dropbox.com/ 查看“登录”的下拉菜单链接。我如何创建这样的下 zipper 接? 最佳答案 这是 fiddle
我正在制作一个 Liferay 主题,但我在尝试设计导航菜单的样式时遇到了很多麻烦。我已经为那些没有像这样下拉的人改变了导航链接上的经典主题悬停功能: .aui #navigation .nav li
如果您将鼠标悬停在 li 上,则会出现一个下拉菜单。如果您将指针向下移至悬停时出现的 ul,我希望链接仍然带有下划线,直到您将箭头从 ul 或链接移开。这样你就知道当菜单下拉时你悬停在哪个菜单上。 知
我有一个带有多个下拉菜单的导航栏。因此,当我单击第一个链接时,它会打开下拉菜单,但是当我单击第二个链接时,第一个下拉菜单不会关闭。 (所以如果用户点击第二个链接我想关闭下拉菜单) // main.js
我正在尝试制作一个导航下拉菜单(使用 Bootstrap 3),其中链接文本在同一行上有多个不同的对齐方式。 在下面的代码中,下拉列表 A 中的链接在 HTML 中有空格字符来对齐它们,但是空白被忽略
我希望有人能帮我解决这个 Bootstrap 问题,因为我很困惑。 有人要求我在底部垂直对齐图像和其中包含图像的链接。 我面临的问题是他们还希望链接在链接/图像组合上具有 pull-right,这会杀
我正在构建一个 Rails 应用程序,并希望指向我的类的每个实例的“显示”页面的链接显示在“索引”页面的下拉列表中。我目前正在使用带有 options_from_collection_for_sele
我有以下 Bootstrap3 导航菜单 ( fiddle here )。我想设置“突出显示”项及其子链接与下拉列表 1 和 2 链接不同的链接文本(和悬停)的样式。我还希望能够以不同于 Highli
我对导航栏中的下拉菜单有疑问。对于普通的导航链接(无下拉菜单),我将菜单文本放在 H3 中,但是当我尝试对下 zipper 接执行相同操作时,箭头不在标题旁边,而是在标题下方。我决定用 span 替换
我是一名优秀的程序员,十分优秀!