I have a seperate .js file and namespace for json requests. I have another .js file and namespace for the actual logic.
I can't seem to get the result back in my logic layer.
var jsonResult = Blah.Data.LoadAggregates();
alert(jsonResult);
alert(jsonResult.d.length);
alert(jsonResult.length);
all of the above calls are returning undefined.
Blah.RegisterNamespace("Blah.Data");
(function(Data) {
Data.LoadAggregates开发者_Python百科 = function() {
$.ajax({
type: "POST",
url: "asdf.asmx/GetAggregates",
data: "{}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function(data) {
???????
},
error: function(msg) {
alert("error" + msg);
}
});
};
})(Blah.Data);
AJAX calls are asynchronous, meaning that the $.ajax call will not wait for the server to respond.
Therefore, your LoadAggregates function finishes executing before the server replies.
In order to get the server's response, your LoadAggregates function needs to take a callback parameter, the way $.ajax does.
For example:
Data.LoadAggregates = function(callback) {
$.ajax({
type: "POST",
url: "asdf.asmx/GetAggregates",
data: "{}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function(data) {
//Do something to the data if you want to
callback(data); //You can pass any parameters you want
},
error: function(msg) {
alert("error" + msg);
}
});
};
You would then call it like this:
Blah.Data.LoadAggregates(function(jsonResult) {
alert(jsonResult.length);
});
加载中,请稍侯......
精彩评论