2012-09-13 67 views
4

如何正确编写此脚本,以便可以匹配对象上的值。jQuery在多维数组/对象中查找匹配值

var objGroup = [ 
    { "color": "YELLOW", "number": "11,7,44,22" }, 
    { "color": "BLUE", "number": "8,20,9" }, 
    { "color": "GREEN", "number": "12,34,55" } 
]; 
objGroup.map(function (groupNum) { 
    if (groupNum.number== "11") { 
    alert(groupNum.color); 
    } else { 
    return null 
    } 
});​ 
+0

请您描述一下您要做的更详细的工作吗? 您的number-property不是对象或数组。它是一个包含数字的字符串。你的代码中没有使用任何jQuery?!? – LeJared

回答

8

这将返回包含提供的数字的数值的对象。使用更新.filter功能

var objGroup = [ 
    { "color": "YELLOW", "number": "11,7,44,22" }, 
    { "color": "BLUE", "number": "8,20,9" }, 
    { "color": "GREEN", "number": "12,34,55" } 
]; 

var found = findItem(objGroup, '11'); 

function findItem(array, value) { 
    for (var i = 0; i < array.length; i++) { 
     if (array[i].number.split(',').indexOf(value) >= 0) { 
      return objGroup[i]; 
     } 
    } 
} 

if (found) { 
    alert(found.color); 
} 

http://jsfiddle.net/rVPu5/

替代,不会被尽可能广泛的支持:

var found = objGroup.filter(function(item) { 
    if (item.number.split(',').indexOf('11') >= 0) { 
     return true; 
    } 
    return false; 
}); 

if (found.length > 0) { 
    alert(found[0].color); 
} 

http://jsfiddle.net/rVPu5/2/

最后 - jQuery的版本:

var found = $.map(objGroup, function(item) { 
    if (item.number.split(',').indexOf('11') >= 0) { 
     return item; 
    } 
}); 

if (found.length > 0) { 
    alert(found[0].color); 
} 

http://jsfiddle.net/rVPu5/3/

+0

非常感谢你! – kedomonzter