繁体   English   中英

如何在 JavaScript 中过滤 JSON 对象?

[英]How can I filter a JSON object in JavaScript?

我有以下 JSON 字符串:

{
   "Alarm":{
      "Hello":48,
      "World":3,
      "Orange":1
   },
   "Rapid":{
      "Total":746084,
      "Fake":20970,
      "Cancel":9985,
      "Word": 2343
   },
   "Flow":{
      "Support":746084,
      "About":0,
      "Learn":0
   }
}

然后我加载上面的字符串并将其转换为json对象:

jsonStr = '{"Alarm":{"Hello":48,"World":3,"Orange":1},"Rapid":{"Total":746084,"Fake":20970,"Cancel":9985},"Flow":{"Support":746084,"About":0,"Learn":0}}';
var jsonObj = JSON.parse(jsonStr);

现在,如何按键名过滤这个json对象?

例如,如果过滤器是“ange”,则过滤后的对象将是:

{
   "Alarm":{
      "Orange":1
   }
}

如果过滤器是“flo”,则过滤后的对象将变为:

{
   "Flow":{
      "Support":746084,
      "About":0,
      "Learn":0
   }
}

如果过滤器是“wor”,结果将是:

{
   "Alarm":{
      "World": 3,
   },
   "Rapid":{
      "Word": 2343
   }
}

是否可以使用filter方法来实现这种过滤?

除了给定的解决方案之外,您还可以使用递归样式来检查密钥。

该提议提供了在内部拥有更多嵌套对象并仅获取过滤部分的机会。

 function filterBy(val) { function iter(o, r) { return Object.keys(o).reduce(function (b, k) { var temp = {}; if (k.toLowerCase().indexOf(val.toLowerCase()) !== -1) { r[k] = o[k]; return true; } if (o[k] !== null && typeof o[k] === 'object' && iter(o[k], temp)) { r[k] = temp; return true; } return b; }, false); } var result = {}; iter(obj, result); return result; } var obj = { Alarm: { Hello: 48, "World": 3, Orange: 1 }, Rapid: { Total: 746084, Fake: 20970, Cancel: 9985, Word: 2343 }, Flow: { Support: 746084, About: 0, Learn: 0 }, test: { test1: { test2: { world: 42 } } } }; console.log(filterBy('ange')); console.log(filterBy('flo')); console.log(filterBy('wor'));
 .as-console-wrapper { max-height: 100% !important; top: 0; }

您可以使用reduce()Object.keys()创建一个函数,该函数将使用indexOf()检查键名并返回所需的结果。

 var obj = { "Alarm": { "Hello": 48, "World": 3, "Orange": 1 }, "Rapid": { "Total": 746084, "Fake": 20970, "Cancel": 9985, "Word": 2343 }, "Flow": { "Support": 746084, "About": 0, "Learn": 0 } } function filterBy(val) { var result = Object.keys(obj).reduce(function(r, e) { if (e.toLowerCase().indexOf(val) != -1) { r[e] = obj[e]; } else { Object.keys(obj[e]).forEach(function(k) { if (k.toLowerCase().indexOf(val) != -1) { var object = {} object[k] = obj[e][k]; r[e] = object; } }) } return r; }, {}) return result; } console.log(filterBy('ange')) console.log(filterBy('flo')) console.log(filterBy('wor'))

对于filter方法,我认为您的意思是Array#filter函数。 这不适用于对象。

无论如何,输入数据的解决方案可能如下所示:

function filterObjects(objects, filter) {
    filter = filter.toLowerCase();
    var filtered = {};
    var keys = Object.keys(objects);
    for (var i = 0; i < keys.length; i++) {
        var key = keys[i];
        if (objects.hasOwnProperty(key) === true) {
            var object = objects[key];
            var objectAsString = JSON.stringify(object).toLowerCase();
            if (key.toLowerCase().indexOf(filter) > -1 || objectAsString.indexOf(filter) > -1) {
                filtered[key] = object;
            }
        }
    }
    return filtered;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM