Объект массива фильтра дочерние javascript - PullRequest
1 голос
/ 07 марта 2020

Мне нужно отфильтровать массив с дочерними элементами

Я использую функцию .filter и не фильтрую дочерние элементы так, как мне нужно

Это пример объекта

var arr =  {
       "items":[
          {
             "name":"Stackoverflow",
             "type":"development",
             "children":[
                {
                   "title":"web",
                   "titleName":"web site"
                },
                {
                   "title":"web",
                   "titleName":"site"
                }
             ]
          },
          {
             "name":"Jon Snow",
             "type":"actor",
             "children":[
                {
                   "title":"foo 2",
                   "titleName":"foo 3"
                },
                {
                   "title":"no foo",
                   "titleName":"bar 2"
                }
             ]
          }
       ]
    }

Пример кода:

var searchWord = 'foo'

arr.items.filter(item => {
    return (item.children.some(c => c.titleName.indexOf(searchWord) > -1))
})

это вернет элементы, которые имеют фильтр правильно, но мне нужно, чтобы фильтры потомков возвращались

//The returned children
{ 
 "name":"Jon Snow",
 "type":"actor",
 "children":[{title: "foo 2", titleName: "foo 3"}, {title: "no foo", titleName: "bar 2"}]
}
//The expected should be 
{ 
 "name":"Jon Snow",
 "type":"actor",
 "children":[{title: "foo 2", titleName: "foo 3"}]
}

Ответы [ 2 ]

1 голос
/ 07 марта 2020

попробуйте

arr.items.filter(item => {
   if (item.children.some(c => c.titleName.indexOf(searchWord) > -1)){
        console.log(item);
      item.children=item.children.find(x=>x.titleName.indexOf(searchWord) > -1);
      return item
   }
})

https://jsfiddle.net/ahwctv8q/

0 голосов
/ 07 марта 2020

Вы на самом деле не фильтруете дочерние элементы, вы фильтруете только элементы верхнего уровня.

Это должно работать правильно:

var searchWord = 'foo'
res = arr.items.filter(item => {
  item.children = item.children.filter(c => c.titleName.indexOf(searchWord) > -1);
  return (item.children.length > 0);
})
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...