在对象属性下搜索对象数组,以获取JavaScript

时间:2015-10-28 21:39:15

标签: javascript

我正在使用一个JavaScript库,其中包含一些代码,这些代码需要像这样的简单平面数组......

var items = [
    'item 1',
    'item 2',
    'item 3',
];

这对我的项目需求来说太有限了所以我正在编辑库以接受一个对象数组而不是像这样...

var items = [
    {
        id: 1,
        name: 'Item 1',
        image: 'img 1',
    },
    {
        id: 2,
        name: 'Item 2',
        image: 'img 2',
    },
    {
        id: 3,
        name: 'Item 3',
        image: 'img 3',
    },
]; 

库调用这样的代码......

if (_helpers.inArray(val, this.options.items) || (val === '')) {
    return val;
}

检查字符串是否在items数组中。

因为我的items数组不再是一个简单的字符串值,而是一个对象。这打破了这部分库代码。

它调用的函数的代码是......

var _helpers = {

    inArray: function(val, arr) {
        return ($.inArray(val, arr) !== -1);
    },

};

所以我需要一些帮助来制作我自己的_helpers.inArray(val, this.options.items)函数,该函数将检查对象属性name下的对象数组中的字符串值

任何帮助表示赞赏

2 个答案:

答案 0 :(得分:2)

可能是这样的吗?

var _helpers = {
    inArray: function(val, arr) {
        for (var i = 0; i < arr.length; i++){
            if (arr[i].name === val)
                return true;
        }
        return false;
    },
};

https://jsfiddle.net/z54qnukd/1/

答案 1 :(得分:1)

尝试将对象数组映射回简单格式:

var _helpers = {

    inArray: function(val, arr) {
        var mappedArr = $.map( items, function(item, index) {
            return item.name;
        });
        return ($.inArray(val, mappedArr) !== -1);
    },

};

https://jsbin.com/tihuyuquni/edit?html,output