JavaScript中的解构赋值

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (49)

从Mozilla的JavaScript 1.7版本中可以看出,他们增加了解构赋值。可悲的是我不喜欢语法(为什么要写两次?):

var a, b;  
[a, b] = f();

像这样的东西会好很多:

var [a, b] = f();

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

无论如何,我已经能够提出的JavaScript 1.5的最佳解决方案是:

function assign(array, map) {
    var o = Object();
    var i = 0;
    $.each(map, function(e, _) {
        o[e] = array[i++];
    });
    return o;
}

其工作原理如下:

var array = [1,2];
var _ = assign[array, { var1: null, var2: null });
_.var1; // prints 1
_.var2; // prints 2

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

什么是更好的解决方案?

提问于
用户回答回答于

首先,var [a, b] = f()在JavaScript 1.7中工作得很好 - 试试吧!

其次,您可以使用以下方法略微修改使用语法with()

var array = [1,2];
with (assign(array, { var1: null, var2: null }))
{
   var1; // == 1
   var2; // == 2
}

当然,这不会允许您修改现有变量的值,所以恕我直言,它比JavaScript 1.7功能要少得多。在代码中,我正在写现在,我只返回对象直接和参考其成员-我会等待1.7功能越来越广泛。

用户回答回答于

你不需要虚拟的“_”变量。您可以使用窗口对象作用域直接创建“全局”变量:

window["foo"] = "bar";
alert(foo); // Gives "bar"

这里有几点:

  • 我不会将这个函数命名为“assign”,因为这个术语太笼统了。
  • 为了更接近JS 1.7的语法,我会让函数把目的地作为第一个参数,把源作为第二个参数。
  • 使用对象字面值来传递目标变量是很酷的,但是可能会被JS 1.7解构造混淆,其中目标实际上是一个对象而不是一个数组。我更喜欢用逗号分隔的变量名列表作为字符串。

以下是我想到的:

function destructure(dest, src) {  
    dest = dest.split(",");  

    for (var i = 0; i < src.length; i++) {  
        window[dest[i]] = src[i];  
    }  
}  

var arr = [42, 66];  

destructure("var1,var2", arr); 

alert(var1); // Gives 42
alert(var2); // Gives 66

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励