在javascript中返回多个值?

时间:2011-02-08 19:54:11

标签: javascript

有没有办法使用一种类似C#的outref参数修饰符和Javascript来做这样的事情:

function myManyReturnFunction(number1, number2, out x, out y) {
    x = number1 * number2;
    y = number1 / number2;

    return true;
}

var height1, height2 = 0;
var check = myManyReturnFunction(1,1, out height1, out hight2);

我也想改变变量的引用。所以是的,通过引用传递参数。

5 个答案:

答案 0 :(得分:19)

function myManyReturnFunction(number1, number2) {
    return {
        x: number1 * number2,
        y: number1 / number2
    }
}

您不需要xy参数,只需致电:

var result = myManyReturnFunction(6, 9);
var x = result.x;
var y = result.y;

答案 1 :(得分:3)

您可以创建“对象”......

function getObj(){
var objOut = new Object();
objOut.name = "Smith";
objOut.State = "Arkansas";

return objOut;
}

答案 2 :(得分:3)

如果在外部全局范围内定义'out'变量,如果你的函数可以在函数内部重新分配它们:

var height1 = 0, height2 = 0;

function myManyReturnFunction(number1, number2) {
    height1 = number1 * number2;
    height2 = number1 / number2;

    return true;
}


var check = myManyReturnFunction(1,1);

您还可以创建一个对象,然后将其传递给您的函数,该函数可以在函数中进行修改,如下所示:

var myValues = {}

function setValues(num1, num2, vals) {
  vals.x = num1 * num2;
  vals.y = num1 / num2;

  return True;
}

setValues(1, 1, myValues);

答案 3 :(得分:2)

有几种方法可以在JavaScript中返回多个值。您始终能够在数组中返回多个值:

function f() {
    return [1, 2];
}

然后像这样访问它们:

var ret = f();
document.write(ret[0]); // first return value

但是JavaScript 1.7中的语法更好,增加了解构分配(如果你足够幸运,可以定位支持它的环境(例如Firefox扩展)):

var a, b;
[a, b] = f();
document.write("a is " + a + " b is " + b + "<br>\n");

另一种选择是返回包含值的对象文字:

function f() {
    return { one: 1, two: 2 };
}

然后可以通过名称访问:

var ret = f();
document.write(ret.one + ", " + ret.two);

当然,你可以做一些非常可怕的事情,例如修改全局范围甚至设置函数本身的属性:

function f() {
    f.one = 1;
    f.two = 2;
}

f();

document.write(f.one + ", " + f.two);

更多阅读(以及其中一些例子的来源):

https://developer.mozilla.org/en/New_in_JavaScript_1.7#Destructuring_assignment_(Merge_into_own_page.2fsection

答案 4 :(得分:0)

您可以返回非基本类型:

function blah() {
  return { name: 'john', age: 23 };
};

var x = blah();