ajax回调函数结束后怎么再触发ajax,如何将回调函数传递给$ .ajax.done回调?

我正在调用一个函数,它会将ajax GET设为一个url,如下所示:

// parameters = url, callback, boolean

that.mapUrl( window.location.search, function(spec) {

console.log("initial mapping done");

console.log(spec);

// do stuff

}, true);

mapUrl将触发Ajax请求。在Ajax done或success处理程序中,我想触发我的回调函数,但是这样做:

$.ajax({

method: 'GET',

url: obj[1],

context: $('body')

}).fail(function (jqXHR, textStatus, errorThrown) {

console.log("FAILED");

configuration = {

"errorThrown":errorThrown,

"textStatus": textStatus,

"jqXHR": jqXHR

}

}).done(function(value, textStatus, jqXHR) {

console.log("OK");

console.log(callback) // undefined!

configuration = {

"value":value,

"textStatus": textStatus,

"jqXHR": jqXHR

}

});

问题:

所以我想知道如何将我的回调函数传递到ajax done-callback。知道怎么做吗?

谢谢!

修改

这是完整的mapURL函数

that.mapUrl = function (spec, callback, internal) {

var key,

obj,

parsedJSON,

configuration = {"root" : window.location.href};

if (spec !== undefined && spec !== "") {

obj = spec.slice(1).split("=");

key = obj[0];

console.log(key);

switch (key) {

case "file":

$.ajax({

method: 'GET',

url: obj[1],

context: $('body')

}).fail(function (jqXHR, textStatus, errorThrown) {

console.log("FAILED");

configuration = {

"errorThrown":errorThrown,

"textStatus": textStatus,

"jqXHR": jqXHR

}

}).done(function(value, textStatus, jqXHR) {

console.log("OK");

configuration = {

"value":value,

"textStatus": textStatus,

"jqXHR": jqXHR

}

});

break;

default:

// type not allowed, ignore

configuration.src = [];

break;

}

}

return configuration;

};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值