Javascript 使用jQuery从web服务获取JSON

Javascript 使用jQuery从web服务获取JSON,javascript,jquery,web-services,Javascript,Jquery,Web Services,因此,我的javascript看起来像: try { var response = $.ajax({ type: "GET", contentType: "application/json; charset=utf-8", url: "BudgService.asmx/LoadDetail", data: "{'building': '63170', 'CurrentYear'

因此,我的javascript看起来像:

    try {
        var response = $.ajax({
            type: "GET",
            contentType: "application/json; charset=utf-8",
            url: "BudgService.asmx/LoadDetail",
            data: "{'building': '63170', 'CurrentYear':'2014'}",
            dataType: "json"
        });
        $.when(response).then(function () {
            loadData();
        });
    } catch (err) {
        alert(err);
    }

    function LoadData() {
        alert('here');
    }
和web服务

    [ScriptMethod]
    public string LoadDetail(string building, string CurrentYear) {
        return "[{color:\"red\", value: \"#f00\"}]";
    }
但我从未使用loadData函数,响应中也没有填充任何内容

我缺少什么?

您的JSON无效

请回答:

在JavaScript对象文字语法中,属性名称可以是字符串或标识符,但在JSON中它们必须是字符串

"[{\"color\":\"red\", \"value\": \"#f00\"}]"
应您的要求:

在JavaScript中,字符串可以用
字符分隔,但在JSON中,字符串必须用
字符分隔

data: '{"building": "63170", "CurrentYear":"2014"}',
根据经验,最好构建一个本机数据结构,然后使用JSON库将其序列化为JSON,而不是手工制作JSON


此外,GET请求中不能包含请求正文。您需要使用POST。

当您直接在浏览器中访问
BudgService.asmx/LoadDetail
时会得到什么?