尽管我已经阅读了一些与此类似的帖子,但我似乎无法使其正常工作。我有以下在按下按钮时调用的 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 中才会在回调后触发警报框。
非常感谢您的帮助。