1

尽管我已经阅读了一些与此类似的帖子,但我似乎无法使其正常工作。我有以下在按下按钮时调用的 Ajax。

   function refreshTab(){
           theObject = {
               getArray: function(callback) {

                   $.ajax({
                       url: 'urlGoeshere',
                       data: "",
                       type: "GET",
                       dataType: 'json',
                       success: function(data)         
                       {                                                          
                           callback.call(this,data);
                           alert("testing");
                       },
                       error: function (err)
                        {
                            alert(err.responseText)
                        }
                   });
               }
           }
           theObject.getArray(function(data) {
               javascript: console.log(data);
               for(i=0;i<data.length;i++){
                   auditHolder = auditHolder + "<tr class='gradeU'><br><td>" + data[i].Description + "</td><td style='width:100px' align='center'>" + data[i].CreatedOn + "</td><br></tr>"
                   // $('#container tbody').append("<tr class='gradeU'><br><td>" + data[i].Description + "</td><td style='width:100px' align='center'>" + data[i].CreatedOn + "</td><br></tr>");

               }
               $('#container tbody').html(auditHolder);

           });                                          
       }

上面的代码在 Chrome 中完美运行,但在 FF 或 IE 中都不起作用。目前使用 jQuery 1.4.4。

通过 alert("testing"); 我发现似乎破坏代码的行是

     callback.call(this,data);

在它在所有浏览器中工作之前放置一个警报框但是只有在 Chrome 中才会在回调后触发警报框。

非常感谢您的帮助。

4

1 回答 1

0

我刚刚遇到了同样的问题,发现旧版本的 Firefox、jQuery 和 Firebug (!!) 的组合是这个问题的原因。也可以看看:

http://bugs.jquery.com/ticket/6349

于 2014-01-21T13:07:20.183 回答