Javascript 使用jQuery从web服务获取JSON
因此,我的javascript看起来像: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'
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
时会得到什么?