首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在JavaScript中解构赋值

在JavaScript中解构赋值
EN

Stack Overflow用户
提问于 2008-10-15 11:56:08
回答 1查看 10.6K关注 0票数 16

可以在JavaScript 1.7的Mozilla更改日志中看到,他们已经添加了解构任务。遗憾的是,我不太喜欢它的语法(为什么要写a和b两次呢?):

代码语言:javascript
复制
var a, b;  
[a, b] = f();

像这样的东西会好得多:

代码语言:javascript
复制
var [a, b] = f();

这仍然是向后兼容的。类似Python的解构不会向后兼容。

无论如何,我所能想到的JavaScript 1.5最好的解决方案是:

代码语言:javascript
复制
function assign(array, map) {
    var o = Object();
    var i = 0;
    $.each(map, function(e, _) {
        o[e] = array[i++];
    });
    return o;
}

它的工作原理如下:

代码语言:javascript
复制
var array = [1,2];
var _ = assign[array, { var1: null, var2: null });
_.var1; // prints 1
_.var2; // prints 2

但这真的很糟糕,因为_没有任何意义。它只是一个空的shell来存储名字。但遗憾的是,它是必需的,因为JavaScript没有指针。从好的方面来说,您可以在值不匹配的情况下指定默认值。另请注意,此解决方案不会尝试对数组进行切片。所以你不能做像{first: 0, rest: 0}这样的事情。但是,如果有人想要这样的行为,那是很容易做到的。

什么是更好的解决方案?

EN

回答 1

Stack Overflow用户

发布于 2013-09-15 03:48:56

在标准的JavaScript中,我们已经习惯了各种各样的丑陋,并且使用中间变量模拟解构赋值并不是很糟糕:

代码语言:javascript
复制
function divMod1(a, b) {
    return [ Math.floor(a / b), a % b ];
}

var _ = divMod1(11, 3);
var div = _[0];
var mod = _[1];
alert("(1) div=" + div + ", mod=" + mod );

然而,我认为下面的模式更具同一性:

代码语言:javascript
复制
function divMod2(a, b, callback) {
    callback(Math.floor(a / b), a % b);
}

divMod2(11, 3, function(div, mod) {
    alert("(2) div=" + div + ", mod=" + mod );
});

请注意,我们不是将两个结果作为数组返回,而是将它们作为参数传递给回调函数。

(请参阅在http://jsfiddle.net/vVQE3/上运行的代码)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/204444

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档