4

私はかなりの数の関連する質問とグーグルの結果を見てきましたが、どれも私の問題に一致しないようです。

''に連結したい文字列"header.h2"を取得していますvar objects。だから私は欲しいobjects.header.h2(より多くのハッシュデータを含む)。

ただし、 ]が機能せず、必要になるbuttons[]という明らかな理由から、eval()や頻繁に提案されるものは使用したくありません。buttons[header.h2buttons[header][h2]

では、どうすればオブジェクト表記を維持できますか、最悪の場合、問題を解決できますか?

4

2 に答える 2

8

可能な方法の簡単なスケッチ:

あなたのデータ

var data = [
    {foo: 1, bar: 2, foobar: [
        'a', 'b', 'c'
    ]},
    {foo: 1, bar: 2, foobar: [
        'd', 'e', 'f'
    ]},
    {foo: 1, bar: 2, foobar: [
        'g', 'h', 'i'
    ]}
];

var accessor = '1.foobar.2';

ヘルパー関数の使用

function helper(data, accessor) {
    var keys = accessor.split('.'),
        result = data;

    while (keys.length > 0) {
        var key = keys.shift();
        if (typeof result[key] !== 'undefined') {
            result = result[key];
        }
        else {
            result = null;
            break;
        }
    }

    return result;
}

または、すべてのオブジェクトで利用できるようにします:(個人的にはこれは好きではありません...)

Object.prototype.access = function (accessor) {
    var keys = accessor.split('.'),
        result = this;

    while (keys.length > 0) {
        var key = keys.shift();
        if (typeof result[key] !== 'undefined') {
            result = result[key];
        }
        else {
            result = null;
            break;
        }
    }

    return result;
};

デバッグ出力

console.log(
    helper(data, accessor), // will return 'f'
    data.access(accessor) // will return 'f'
); 
于 2011-04-13T09:09:54.437 に答える
3

与えられたドット表記文字列ごとにオブジェクトを作成する「populate」メソッドを作成します。

var populate = function(obj, str) {
  var ss=str.split(/\./), len=ss.length, i, o=obj;
  for (i=0; i<len; i++) {
    if (!o[ss[i]]) { o[ss[i]] = {}; }
    o = o[ss[i]];
  }
  return obj;
};

var objects = populate({}, 'header.h2');
objects.header.h2; // => Object {}
populate(objects, 'foo.bar.gah.zip');
objects.foo.bar.gah.zip; // => Object {}

テストが必要ですが、目標に近づくはずです。

于 2011-04-13T09:26:54.067 に答える