JavaScript中返回一个值和返回一个表达式有区别吗?
Is there a difference between returning a value and returning an expression in JavaScript?
我的一个朋友刚刚问我以下两个表达方式中哪个是更好的选择。虽然我理解这个问题,因此更好的定义可能是一个意见问题,因此是题外话;我很想知道是否有充分的理由支持一个。
var count = _.reduce(randomData, function(prefix, businessData){
return prefix + businessData.length;
}, 0);
return {
name: randomName,
pos: position[randomName],
count: count
};
或
return {
name: randomName,
pos: position[randomName],
count:
_.reduce(randomData, function(prefix, businessData){
return prefix + businessData.length;
}, 0)
};
我和另一位同事一致认为第一个会更好,因为它更清晰,可能更容易调试并且更容易理解,但除此之外我们无法证明我们的选择是正确的。
是否有理由支持返回值而不是返回表达式?
Is there a difference between returning a value and returning an expression in JavaScript?
不,您return无论哪种方式都在计算一个值。更准确地说,根据您的代码示例,您正在为对象的 count
属性 分配一个值,您正在 return 引用任何一种方式。
您的代码示例中的唯一区别是调用 reduce
的时间。在第一个中,它在您 returning 对象的构造开始之前被调用。在第二个中,它在构建过程中被调用。不过,函数随后进入 return 的内容没有区别。
Is there a reason why one would favour returning the value against returning the expression?
由于上面的第一个答案是 "no," 唯一的原因让我们进入,或者至少非常接近,意见领域。
我能想到的最接近的 objective 措施是您指出的措施之一:调试。对于第一个,您可以在构造和 returning 对象之前轻松地看到 count
。第二个,就更难了。
关于这个对象构造的更多细节,以防万一:JavaScript 定义对象初始化器中 属性 初始化器的顺序 运行:不出所料,它们按源代码顺序 运行。例如,如果我们有这样的代码:
var num = 0;
function foo() {
return ++num;
}
var obj = {
a: foo(),
b: foo(),
c: foo()
};
...我们确定obj.a
的值为1,obj.b
的值为2,obj.c
的值为3。这是规范定义的。
我的一个朋友刚刚问我以下两个表达方式中哪个是更好的选择。虽然我理解这个问题,因此更好的定义可能是一个意见问题,因此是题外话;我很想知道是否有充分的理由支持一个。
var count = _.reduce(randomData, function(prefix, businessData){
return prefix + businessData.length;
}, 0);
return {
name: randomName,
pos: position[randomName],
count: count
};
或
return {
name: randomName,
pos: position[randomName],
count:
_.reduce(randomData, function(prefix, businessData){
return prefix + businessData.length;
}, 0)
};
我和另一位同事一致认为第一个会更好,因为它更清晰,可能更容易调试并且更容易理解,但除此之外我们无法证明我们的选择是正确的。
是否有理由支持返回值而不是返回表达式?
Is there a difference between returning a value and returning an expression in JavaScript?
不,您return无论哪种方式都在计算一个值。更准确地说,根据您的代码示例,您正在为对象的 count
属性 分配一个值,您正在 return 引用任何一种方式。
您的代码示例中的唯一区别是调用 reduce
的时间。在第一个中,它在您 returning 对象的构造开始之前被调用。在第二个中,它在构建过程中被调用。不过,函数随后进入 return 的内容没有区别。
Is there a reason why one would favour returning the value against returning the expression?
由于上面的第一个答案是 "no," 唯一的原因让我们进入,或者至少非常接近,意见领域。
我能想到的最接近的 objective 措施是您指出的措施之一:调试。对于第一个,您可以在构造和 returning 对象之前轻松地看到 count
。第二个,就更难了。
关于这个对象构造的更多细节,以防万一:JavaScript 定义对象初始化器中 属性 初始化器的顺序 运行:不出所料,它们按源代码顺序 运行。例如,如果我们有这样的代码:
var num = 0;
function foo() {
return ++num;
}
var obj = {
a: foo(),
b: foo(),
c: foo()
};
...我们确定obj.a
的值为1,obj.b
的值为2,obj.c
的值为3。这是规范定义的。