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,因为我认为这是一个公平的问题。我认为这是因为你没有真正解释你的问题是什么,没有说明你收到了什么输出。你自己尝试过什么吗?函数应该返回什么,字符串?如果它现在返回匹配的对象,它是否应该不再这样做(因为不能同时返回两个对象)?我的直觉是,作为一个递归函数,您必须在某个地方遇到一些溢出,并在返回之前退出。