如何在JavaScript中使用defineProperty制作动态getter?

时间:2013-12-22 14:15:52

标签: javascript dynamic defineproperty

我想在JavaScript中使用defineProperty定义动态getter函数,如下所示。为了创建只读函数,我想使用defineProperty。这使我能够在setter函数中抛出异常。

但是getter功能不起作用。我认为这个getter动态地返回obj的任何属性。但事实并非如此。它总是返回obj["three"],最后一个属性。是否有任何方法可以使动态getter在JavaScript中返回适当的属性?

var obj = {"one":1, "two":2, "three":3};
var cloned = {};

for (var prop in obj) 
{
    var getter = makeGetter(prop);
    Object.defineProperty(cloned, prop, 
    {
        set: function() 
        {
            throw new UnableRewriteException('original cannot be rewrite');
        },
        get: function() 
        {
            return obj[prop]
        },
        enumerable: true
    });
}

1 个答案:

答案 0 :(得分:1)

正如@ paul-s所提到的,你的循环中有一个闭包问题。一个简单的解决方法:

var obj = {"one":1, "two":2, "three":3};
var cloned = {};

function makeReadOnlyProperty(cloned, obj, prop) {
    Object.defineProperty(cloned, prop, 
    {
        set: function() 
        {
            throw new UnableRewriteException('original cannot be rewrite');
        },
        get: function() 
        {
            return obj[prop]
        },
        enumerable: true
    });
}

for (var prop in obj) 
{
    makeReadOnlyProperty(cloned, obj, prop);
}