0

我有个问题

我的页面中有一个脚本,它执行一些操作,例如从表中删除一行,通过 jquery ajax 在表中添加一行。

但是,当我使用 ajax 添加新行时,此行不起作用。

所以有一种方法可以让我每 N 秒重新加载一次这个脚本?!?

 <script>
  .... some stuff ....
 setInterval(function() {
  #reload script or something like that
 },2000);
 </script>

例如这个功能点击打开一条消息......

HTML

  <table>

  <tr class='MessageList' id='a_1'><td>1</td></tr>
  <tr class='MessageList' id='a_2'><td>2</td></tr>
  <tr class='MessageList' id='a_3'><td>3</td></tr>
  </table>

JS

        $('.MessageList').click(function(){
    var id=this.id;
    if(openMessage)
    {
        if($('#read-message').attr('message')==$('#'+id).attr('data'))
        {
            $('#message-list').addClass('hide');
            $('#read-message').removeClass('hide');
        }
        else
        {
        var readMsg=true;
        if($('#'+id).hasClass('not_viewed'))
        {
            readMsg=false;
            jQuery.ajax({
            type: "POST",
            url: "<?php echo AJAX_RE;?>/nvinbox/",
            data: "b=" + $('#'+id).attr('view') + "&a=<?php echo $_SESSION['registrar']['inbox'] ?>",
            cache: true,
            async: false,
            error: function(){
            wAlert({ title: "<?php echo $this->languages["PLEASE_TRY_LATER"] ?>",description: "<?php echo $this->languages["SOMETHING_WRONG"] ?>",redirect:'<?php echo USER_REGISTRAR_PAGE?>inbox/'});
            },      
            success: function (response) {
                if(response!='No direct script access allowed')
                {
                    var arr = id.split("_");
                    $('#message_'+arr[1]).addClass('viewed').removeClass('not_viewed');
                    readMsg=true;
                }
                else wAlert({ title: "<?php echo $this->languages["PLEASE_TRY_LATER"] ?>",description: "<?php echo $this->languages["SOMETHING_WRONG"] ?>"});
            }
            });
        }
        if(readMsg)
        {
            jQuery.ajax({type: "POST",url: "<?php echo AJAX_RE;?>/upinbox/",dataType : "json",
            success: function (response) {
            $('#notifMessage').remove();
            $('#messageInbox').append(response[0]);
            if(response[1]!=0){}
            }});

            $('#read-message').remove();
            jQuery.ajax({
            type: "POST",
            url: "<?php echo AJAX_RE;?>/vinbox/",
            data: "c="+id+"&b=" + $('#'+id).attr('data') + "&a=<?php echo $_SESSION['registrar']['inbox'] ?>",
            cache: true,
            async: false,
            error: function(){
            wAlert({ title: "<?php echo $this->languages["PLEASE_TRY_LATER"] ?>",description: "<?php echo $this->languages["SOMETHING_WRONG"] ?>",redirect:'<?php echo USER_REGISTRAR_PAGE?>inbox/'});
            },      
            success: function (response) {
                if(response!='No direct script access allowed')
                {
                    var arr = id.split("_");
                    $('.email-content').append(response);
                    $('#message-list').addClass("hide");
                    $('#read-message').removeClass("hide");
                }
                else wAlert({ title: "<?php echo $this->languages["PLEASE_TRY_LATER"] ?>",description: "<?php echo $this->languages["SOMETHING_WRONG"] ?>"});
            }
            });
        }
    }
    }
    else openMessage=true;
});

当我在表中添加新行时

  <table>
  <!-- new row HERE -> <tr class='MessageList' id='a_1456'><td>1456</td></tr>

  <tr class='MessageList' id='a_1'><td>1</td></tr>
  <tr class='MessageList' id='a_2'><td>2</td></tr>
  <tr class='MessageList' id='a_3'><td>3</td></tr>
  </table>

如果我单击新行 tr 不起作用...但其他工作正常...

4

0 回答 0