0

我有一个像这样的对象:

var theObject = { 
    keyName1: { keyName2: value2, keyName3: value3, keyName4: value40 },
    ...,
    keyName10: { keyName2: value6, keyName3: value7, keyName4: value8 }
}

theObject["keyName10"]["keyName3"]我知道我可以通过or引用 value7,theObject.keyName10.keyName3 但我需要将一个变量设置为类似搜索路径的东西,并以某种方式将其传递给theObject并直接获取 value7。

就像是:

var path = keyName10.keyName3;
var myValue = theObject(path);

对象甚至可以进一步进入对象初始阶段。现在我正在通过看起来很糟糕的嵌套 for 循环来解决它。我错过了更好的方法吗?

4

2 回答 2

1

我只是尝试添加一个有趣的解决方案。我绝对不会像这样使用它,但这个想法可能适用于你的情况。我也质疑这种方法的效率。

var theObject = { 
    keyName1: { keyName2: value2, keyName3: value3, keyName4: value40 },
    ...,
    keyName10: { keyName2: value6, keyName3: value7, keyName4: value8 }
}
var path = 'keyName10/keyName3';


function getProp(theObject, path){
    var parts = path.split("/"),
    idx = parts[0],
    newParts = parts.splice(0, 1),
    newPath = newParts.join("/"),
    obj = theObject[idx];

    // add some validation and error handling in case or error on path 
    // or missing property on obj


    // I do not like the line below, would need to find a better way to see
    // if the function return something or it does some recursion
    // need to figure the right condition to see if we are at des
    if(parts.length == 1) {
        return obj;
    } else {
       return getProp(obj, newPath);
    }
}

可能有帮助:如何检查对象是否在 JavaScript 中具有属性?

于 2013-03-07T12:09:06.097 回答
0

为什么不创建一个getter函数...

var path = 'keyName10/keyName3'

function getTheThing(key){
    var parts = key.split("/")
    return theObject[parts[0]][parts[1]]
}

var myValue = getTheThing(path)

您可以通过将对象和 getter 的键传递给它来使其更通用,从而允许使用路径来访问不同的对象...

var path = 'keyName10/keyName3'

function getTheThing(key, obj){
    var parts = key.split("/")
    return obj[parts[0]][parts[1]]
}

var myValue = getTheThing(path,theObject)
于 2013-03-06T22:51:15.960 回答