Javascript 嵌套对象中匹配键值对的路径
我试图在嵌套对象中实现搜索Javascript 嵌套对象中匹配键值对的路径,javascript,jquery,Javascript,Jquery,我试图在嵌套对象中实现搜索 // Returns an array of matching objects function getObjects(obj, key, val) { var objects = []; for (var i in obj) { if (!obj.hasOwnProperty(i)) continue; if (typeof obj[i] == 'object') {
// Returns an array of matching objects
function getObjects(obj, key, val) {
var objects = [];
for (var i in obj) {
if (!obj.hasOwnProperty(i)) continue;
if (typeof obj[i] == 'object') {
objects = objects.concat(getObjects(obj[i], key, val));
} else if (!$.isNumeric(obj[key]) && i == key && obj[key].toLowerCase().match(val)) {
objects.push(obj);
}
}
return objects;
}
此函数根据提供的键值对返回匹配对象
我想要的是找到键值对的对象的路径
样本数据
TestObj = {
"Categories": [{
"Product1": [{
"id": "a01",
"name": "Pine",
"description": "Short description of pine."
}, {
"id": "a02",
"name": "Pine",
"description": "Short description of pine."
}, {
"id": "a03",
"name": "Poplar",
"description": "Short description of poplar."
}],
"id": "A",
"title": "Cheap",
"description": "Short description of category A."
}, {
"Product2": [{
"id": "b01",
"name": "Maple",
"description": "Short description of maple."
}, {
"id": "b02",
"name": "Oak",
"description": "Short description of oak."
}, {
"id": "b03",
"name": "Bamboo",
"description": "Short description of bamboo."
}]
}]
};
我在试着写一个函数
function objPath(obj, key, val, path) {
var result = [];
var passName = '';
if (path) {
passName = path;
}
var tempArray = [];
for (var prop in obj) {
var value = obj[prop];
if (typeof value === 'object') {
tempArray = objPath(value, key, val, passName);
$.each(tempArray, function (k, value) {
result.push(value);
});
} else if (prop == key && obj[key].toLowerCase().match(val)) {
result.push(obj[key]);
}
}
return result;
}
如果我将函数调用为
objPath(TestObj, 'id', 'b03');
它应该返回Categories>Product2>第三行
但我得到的只是钥匙。如何修复objPath函数以获得所需结果我编写了一个自定义函数
function objPath(obj, key, val, path) {
var result = [];
var passName = '';
if (path) {
passName = path;
}
var tempArray = [];
for (var prop in obj) {
var value = obj[prop];
if (typeof value === 'object') {
tempArray = objPath(value, key, val, passName);
$.each(tempArray, function (k, value) {
result.push(value);
});
} else if (!$.isNumeric(obj[key]) && prop == key && obj[key].toLowerCase().match(val)) {
result.push(passName + '["' + obj[prop] + '"]');
} else {
if ($.isNumeric(obj[prop])) {
//passName += ' > ' + obj[prop];
} else {
passName += '["' + obj[prop] + '"]';
}
}
}
return result;
}
哪个会回来
["Categories"]["Product2"]["b03"]
我想问同样的问题(我讨厌没有解释的否决票——如果有人有问题,我的座右铭是“乐于助人”)。无论如何,我给你打了个+1,因为我认为这是一个公平的问题。我认为这是因为你没有真正解释你的问题是什么,没有说明你收到了什么输出。你自己尝试过什么吗?函数应该返回什么,字符串?如果它现在返回匹配的对象,它是否应该不再这样做(因为不能同时返回两个对象)?我的直觉是,作为一个递归函数,您必须在某个地方遇到一些溢出,并在返回之前退出。