请问大神一个关于Ajax执行顺序的有关问题
请教大神一个关于Ajax执行顺序的问题。
一个全局的变量
var JsonData;
我这里有一个Ajax处理的方法
然后我有一个类。
如此,我在执行DrawDropDownList的时候,为什么总是获取不到JsonData呢。
我打断点跟踪了下, 发现是等DrawDropDownList方法里面的所有都执行完以后才会进入GetJson方法,
请问有什么办法把GetJson里面获得的Result数据拿出来么。
不要在
success: function (Result) {
//Do Something
},
我就是想把获得的数据拿出来用, 因为GetJson是一个通用的方法,不想在里面执行单个的逻辑
------解决方案--------------------
呵呵。。不能在回调中return~并且要同步,接分~
------解决方案--------------------
接分吧
------解决方案--------------------
默认是异步的方式,你改为同步的方式吧。
------解决方案--------------------
不建议同步,建议给你的函数增加一个函数参数作为回调函数,将ajax的结果传递到该函数
function GetJson(DataSourceName,callback) {
$.ajax({
type: "post",
url: "Ajax/AjaxData.ashx?MethodName=" + DataSourceName,
contentType: "application/json;",
data: "",
dataType: "json",
success: function (Result) {
JsonData = Result;
callback(JsonData)
},
error: function (result) {
alert("获取信息列表错误");
window.close();
}
});
//return JsonData;
}
------解决方案--------------------
我来看看有分吗?
一个全局的变量
var JsonData;
我这里有一个Ajax处理的方法
- JScript code
function GetJson(DataSourceName) { $.ajax({ type: "post", url: "Ajax/AjaxData.ashx?MethodName=" + DataSourceName, contentType: "application/json;", data: "", dataType: "json", success: function (Result) { JsonData = Result; }, error: function (result) { alert("获取信息列表错误"); window.close(); } }); return JsonData; }
然后我有一个类。
- JScript code
function DrawDropDownList(sFieldRuleMethod) { GetJson(sFieldSourceName); var b = JsonData; }
如此,我在执行DrawDropDownList的时候,为什么总是获取不到JsonData呢。
我打断点跟踪了下, 发现是等DrawDropDownList方法里面的所有都执行完以后才会进入GetJson方法,
请问有什么办法把GetJson里面获得的Result数据拿出来么。
不要在
success: function (Result) {
//Do Something
},
我就是想把获得的数据拿出来用, 因为GetJson是一个通用的方法,不想在里面执行单个的逻辑
------解决方案--------------------
呵呵。。不能在回调中return~并且要同步,接分~
------解决方案--------------------
接分吧
------解决方案--------------------
默认是异步的方式,你改为同步的方式吧。
------解决方案--------------------
不建议同步,建议给你的函数增加一个函数参数作为回调函数,将ajax的结果传递到该函数
function GetJson(DataSourceName,callback) {
$.ajax({
type: "post",
url: "Ajax/AjaxData.ashx?MethodName=" + DataSourceName,
contentType: "application/json;",
data: "",
dataType: "json",
success: function (Result) {
JsonData = Result;
callback(JsonData)
},
error: function (result) {
alert("获取信息列表错误");
window.close();
}
});
//return JsonData;
}
------解决方案--------------------
我来看看有分吗?