在 JavaScript 中使用数组而不是对象

Use array instead of object in JavaScript

本文关键字:对象 数组 JavaScript      更新时间:2023-09-26

>我有以下变量:

    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": []
    };

而且我不知道如何处理它。

而不是

filter[key][val] = true;

怎么样

filter[key].push(val);

filter =  {
    "country": 1,
    "Age Group": [],
                 ^^---empty array, instead of {} for object.

if(typeof filter[key][val] !== "undefined" ) ,你现在拥有的很好,因为对象具有恒定时间查找。如果使用数组扫描,if(filter[key].indexOf(val) !== -1) ,时间复杂度增加到 O(n),因为您必须扫描每个元素以查看它是否在数组中。