0

如果NewMessage发生变化,我想要一个警报。我尝试过liveand change onbind change但没有任何效果。

相关PHP:

$message=6;
    $myReturnData["Message"] = $message; 

  //JSON-encode and return
  print json_encode($myReturnData);

相关的jQuery:

setInterval(function(){
     $.getJSON("foo.php", function(data){
         var NewMessage=(data.Message); 
         if(NewMessage>0){
             document.title= NewMessage + ' pm';}
             $(NewMessage).live("change", function() {
                alert(NewMessage);
                });
      });
   }, 3000);
4

2 回答 2

1

“改变”没有做你认为应该做的事情。您应该将原始消息存储在一个变量中,然后将其与您收到的新消息进行比较。像这样:

var currentMessage = '';
setInterval(function(){
     $.getJSON("foo.php", function(data){
         var NewMessage=(data.Message); 
         if(NewMessage>0){
             document.title= NewMessage + ' pm';
             if (currentMessage !== NewMessage) {
                 alert(NewMessage);
                 currentMessage = NewMessage;
             }
         }
    });
}, 3000);
于 2013-08-12T20:45:47.540 回答
1

假设您希望函数 X 在服务器控制的变量发生更改时运行。这意味着您正在使用轮询机制。

因此,如果您希望您的代码知道何时收到不同的消息,则必须将前一条消息存储在回调函数范围之外的某个位置。

最简单的方法:

var lastMessage = 'the server will never ever forever ever return this message';

setInterval(function(){
    $.getJSON("foo.php", function(data){
        // .. arbitrary code
        if (lastMessage != data.Message)
        {
             alert('it changed');
             lastMessage = data.Message;
        }
        // .. more arbitrary code
    });
}, 3000);

我认为以下代码没有任何意义,甚至可以远程工作,因为NewMessage不是 DOM 元素,是吗?

$(NewMessage).live("change", function() {
            alert(NewMessage);
            });
于 2013-08-12T21:01:29.550 回答