0

私は次の変数を持っています:

    filter =  {
            "country": 1,
            "Age Group": {},
            "Gender": {},
            "NEWSEC": {},
            "Telco_Segment": {}
    };

機能:

function facetBuilder(key, val)
{
    if(key == 'country')
    {   
        filter.country = val;
    }
    else
    {
        if(typeof filter[key][val] !== "undefined" )
        {
            delete filter[key][val]; //I'm assuming you want to remove it
        }
        else
        {
            filter[key][val] = true;
        }
    }

    console.log(filter);
}

結果のオブジェクトは、次のようになります。

    filter =  {
            "country": 1,
            "Age Group": {
                4: true,
                3: true,
                2: true
            },
            "Gender": {
                1: true
            },
            "NEWSEC": {
                3: true,
                2: true
            },
            "Telco_Segment": {}
    };

しかし、私が本当に欲しいのは次のようなものです:

    filter =  {
            "country": 1,
            "Age Group": [4,3,2],
            "Gender": [1],
            "NEWSEC": [3,2],
            "Telco_Segment": []
    };

そして、私はそれにアプローチする方法がわかりません。

4

2 に答える 2

4

それ以外の

filter[key][val] = true;

どうですか

filter[key].push(val);

filter =  {
    "country": 1,
    "Age Group": [],
                 ^^---empty array, instead of {} for object.
于 2012-06-19T18:24:28.030 に答える
0

オブジェクトには一定時間のルックアップがあるため、if(typeof filter[key][val] !== "undefined" )これで は良好です。配列スキャンを使用すると、if(filter[key].indexOf(val) !== -1)各要素をスキャンして配列内にあるかどうかを確認する必要があるため、時間の複雑さが O(n) に増加します。

于 2012-06-19T18:25:42.470 に答える