1

我目前正在使用 Node.js 和 SOcket.io 开发流媒体应用程序。目前该应用程序运行良好,但我需要做一件事:由于它是一个流式应用程序,因此向客户端推送了很多数据,所以我只想显示服务器推送的 10 个最新对象。我怎样才能做到这一点 ?我应该在客户端代码上还是直接在服务器上这样做?我真的不知道。

这是客户端的代码

<script src="/socket.io/socket.io.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.js"></script>
<script>

    var socket = io.connect('http://192.168.1.29:5000');
    socket.on('stream', function(tweet){
    $('#tweetd').append(tweet+'<br>');
    });
</script>
<div id="tweetd"></div>
</div>

服务器代码:

 var express = require('express')
       , app = express()
      , http = require('http')
    , server = http.createServer(app)
      ,Twit = require('twit')
       , io = require('socket.io').listen(server);

  server.listen(8080);

  // routing
  app.get('/', function (req, res) {
  res.sendfile(__dirname + '/index.html');
  });

  var watchList = ['love', 'hate'];
  var T = new Twit({
   consumer_key:         ''
 , consumer_secret:      ''
   ,  access_token:         ''
  , access_token_secret: ''  
 });
 io.sockets.on('connection', function (socket) {
  console.log('Connected');



  T.stream('statuses/filter', { track: watchList },function (stream) {

  stream.on('tweet', function (tweet) {

        io.sockets.emit('stream',tweet.text);
        console.log(tweet.text);

  });
 });
}); 

希望你能帮我 !

4

3 回答 3

0

你必须在一个数组中传送你的推文,而不是发送有限的数组。

于 2013-05-11T09:26:24.653 回答
0

您应该在服务器上执行此操作。节省带宽和时间。

如果您有一个要发回的对象列表,只需在通过 socket.io 发送之前对列表进行切片。

tweets = tweets.slice(tweets.length-10);

现在通过 socket.io 发送你的推文,你只会得到列表中的最后 10 个。

或者,如果您列出的顺序相反:

tweets = tweets.slice(0,10);
于 2013-05-09T21:03:07.853 回答
0

我想我刚刚找到了解决方案。这是代码:

<script>

          var tweetNum = 0;
          var socket = io.connect('/');
          socket.on('stream', function(tweet){
          $('<div id="tweet' + tweetNum + '" class="tweet ' + (((tweetNum++)%2) ? 'odd' : 'even') + '">' +
          '<div class="tw_txt">' + tweet.text + '</div>' +'</div>').prependTo('#tweetd');

          if (tweetNum >= 11) {
            $('#tweet' + (tweetNum - 11)).remove();
          }
        });
  </script>

这可能不是最优雅的方式,但它有效

于 2013-05-11T21:25:04.870 回答