Socket.io向所有客户端发出按钮按下

时间:2017-02-28 05:51:13

标签: jquery node.js express socket.io

向连接到我的服务器的所有客户端发送按钮状态时遇到一些问题。我正在尝试使用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>

1 个答案:

答案 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');

        });