向连接到我的服务器的所有客户端发送按钮状态时遇到一些问题。我正在尝试使用express和socket.io打开来自raspberry托管服务器的灯。
我首先点击客户端的按钮,它会将按钮的状态发送到我的服务器,然后将其发送给所有客户端,点击所有客户端页面上的按钮,然后按钮然后卡在无限循环中并继续点击。
我正在做的过程是否正确?我可以找到很多向所有客户端发送的示例,但我找不到任何发出按钮状态的示例。我也尝试过emit.broadcast,但两个客户轮流发送按钮状态无休止。
有没有人有解决这个问题的建议? 谢谢!
服务器端代码:
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var io = require('socket.io')(server);
var onoff = require('onoff');
var Gpio = onoff.Gpio;
var light = new Gpio(13, 'out');
app.use(express.static(__dirname + '/'));
app.get('/', function(req, res,next) {
res.sendFile(__dirname + '/brew.html');
});
console.log('Starting Server...');
var io = require('socket.io').listen(server);
io.sockets.on('connection', function (client) {
client.on('lightOn',function(on){
light.writeSync(1);
io.emit('lightOn');
});
client.on('lightOff',function(off){
light.writeSync(0);
io.emit('lightOff');
});
});
server.listen(3000);
function lightOn(){
light.writeSync(1);
}
function lightOff(){
light.writeSync(0);
}
客户代码:
<h3 id="h3Brew">Light</h3>
<input type="checkbox" data-toggle="toggle" data-on="Off" data-off="On" id="toggle">
<script>
var socket = io.connect();
$(function() {
$('#toggle').bootstrapToggle({
on: 'ON',
off: 'OFF'
});
})
$("#toggle").change(function(){
if($("#toggle").prop("checked") == true){
socket.emit('lightOn', 'on\n');
}else{
socket.emit('lightOff', 'off\n');}
});
socket.on('lightOn', function() {
$('#toggle').bootstrapToggle('on');
});
socket.on('lightOff', function() {
$('#toggle').bootstrapToggle('off');
});
</script>
答案 0 :(得分:0)
使用全局变量来区分由socked触发的更改事件和由用户触发的更改事件
您可以尝试这样的事情
var websocket = false;
$("#toggle").change(function(){
if(!websocket) {
if($("#toggle").prop("checked") == true){
socket.emit('lightOn', 'on\n');
}else{
socket.emit('lightOff', 'off\n');}
} else {websocket = false;}
});
socket.on('lightOn', function() {
websocket = true;
$('#toggle').bootstrapToggle('on');
});
socket.on('lightOff', function() {
websocket = true;
$('#toggle').bootstrapToggle('off');
});