1

我的 jQuery.ajax() 函数不起作用.. 我想显示来自服务器的 JSON 数据.. 请求成功,我通过 Firebug 发现。当我在“成功”标签中删除功能(数据){时,警报会触发,当功能保留时,它不会..顺便说一句:请求总是成功,当用户名和密码错误时,怎么可能? 但是当我删除xhr.setRequestHeader()方法时,Firebug 显示由于服务器需要基本身份验证,调用以“未经授权”结束。

有什么建议可以解决这个问题吗?提前致谢!

我的javascript“gadget.js”

$.ajax({
    url: "http://localhost:8387/nscalemc/rest/mon/resourcestatus.json",
    type: "GET",
    dataType: "json",
    contentType: "application/json",
    beforeSend: function(xhr) {
        var base64 = btoa('admin' + ":" + 'admin');
        xhr.setRequestHeader("Authorization", "Basic" + base64);
    },
    success: function(data) {
        $(data.groupStatus).each(function() {
            $("body").append("<p>ID: " + this.id + "</p>");
        });
        alert("success!");
    }
}).done(function(data) {
    alert("done!");
    $(data.groupStatus).each(function() {
        $("body").append("<p>ID: " + this.id + "</p>");
    });
}).fail(function(jqXHR, textStatus) {
    alert("fail - " + textStatus);
});​

这是我的 JSON

{
    "groupStatus": [
        {
            "id": "Application Layer Configuration-ApplicationLayer",
            "time": 1332755316976,
            "level": 0,
            "warningIds": [],
            "errorIds": []
        },
        {
            "id": "Application Layer-ApplicationLayer:nscalealinst2",
            "time": 1333431531046,
            "level": 0,
            "warningIds": [],
            "errorIds": []
        }
    ]
}

最后是我的 HTML 类“gadget.html”:

<html>
<head>
    <title>My Gadget</title>
    <link href="css/gadget.css" rel="stylesheet" type="text/css" />
    <script type="text/javascript" src="js/jquery-1.7.2.js"></script>
</head>
<body>
    <div id="content"></div>
    <script type="text/javascript" src="js/gadget.js"></script>
</body>

为什么我的id没有显示?

顺便说一句: .done(function(){})"success: (function(){})有什么区别?

4

1 回答 1

1

我会回答我所知道的:文档中有一条关于 done() 和 success() 之间区别的注释:

弃用通知:jqXHR.success()、jqXHR.error() 和 jqXHR.complete() 回调将在 jQuery 1.8 中弃用。要为最终删除准备代码,请改用 jqXHR.done()、jqXHR.fail() 和 jqXHR.always()。

如果您使用 JSON,则可以使用 getJSON() 而不是 ajax()。希望能帮助到你!。

于 2012-04-04T08:47:47.103 回答