2

我需要对几个不同的 php 脚本运行多个 $.get 函数,我想知道我是否可以在一个通用函数中完成所有操作并返回数据。我的计划是做类似的事情:

var companyName = 'Google';

var customers = get('Customers', companyName);
var vendors = get('Vendors', companyName);

function get(table, variable){
    $.get('http://www.mysite.com/phps/get'+table+'.php', {company: variable}, function(data){return data});
}

但是,这不起作用,因为它位于嵌套函数中。这可能(很容易)还是我必须一次做一个 $.get ?

4

2 回答 2

1

如果您使用的是 jquery 1.5,$.get将返回一个jqXhr对象,该对象实现了 Promise 接口:

从 jQuery 1.5 开始,所有 jQuery 的 Ajax 方法都返回 XMLHTTPRequest 对象的超集。这个由 $.get() 返回的 jQuery XHR 对象或“jqXHR”实现了 Promise 接口,为它提供了 Promise 的所有属性、方法和行为

可以这样使用:

function yourMultipleGetFunction(success, error) {

    var jqXhr1 = $.get('url', data);
    var jqXhr2 = $.get('url2', data2);

    $.when(jqXhr1, jqXhr2).then(success, error);
}

yourMultipleGetFunction(function(data1, data2){
     //handle the objects returned from the get requests
}, function(jqXHR, textStatus, errorThrown){
    //something went wrong, handle the error here
});
于 2013-02-19T22:15:44.617 回答
1

请记住,在 Javascript 中,函数是一等公民,因此您最好发送一个函数,而不是返回一个值:

var companyName = 'Google';

var customers, vendors;

get('Customers', companyName, function(data) { customers = data; });
get('Vendors', companyName, function(data) { vendors = data; });

function get(table, variable, success){
    $.get('http://www.mysite.com/phps/get'+table+'.php', {company: variable}, success);
}

这是一个糟糕的示例,因为它不处理异常等。但它应该让您了解提供给您的灵活性。关键是要记住,函数是语言的基石,也是赋予它力量的东西。

如果你真的想坚持你正在使用的方法(我不推荐),你可以添加一个额外的功能...... (我真的不推荐)

var companyName = 'Google';

var customers, vendors;

get('Customers', companyName, customers);
get('Vendors', companyName, vendors);

function get(table, variable, results){
    $.get('http://www.mysite.com/phps/get'+table+'.php', {company: variable}, function(data){ results = data});
}

这样做会导致您失去根据呼叫结果更改体验处理方式的能力。也许您希望禁用一个选择框,直到呼叫完成并填充它,或者您可能希望在呼叫失败时执行一些特殊操作。使用函数是一种更好的方法。

希望这可以帮助。

于 2013-02-19T23:01:18.250 回答