Как группировать в lodash для каждого элемента во вложенном массиве - PullRequest
1 голос
/ 01 апреля 2019

У меня есть массив json в виде:

    [{
        "published": true,
        "tags": ["tag1", "tag2"],
        "categories": ["cat1"],
        "author": "some name",
        "post-format": "standard",
        "title": "Second Post,",
        "url-slug": "second-post",
        "first-published-on": "2019-03-28",
        "last-updated-on": "2019-03-28",
        "meta": {
            "title": "Second Post",
            "description": "Second post."
        },
        "excerpt": "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt",
        "path": "2019/03/28/SecondPost.md"
    }, {
        "published": true,
        "tags": ["tag1", "tag2", "tag3"],
        "categories": ["cat1", "cat2"],
        "author": "some name",
        "post-format": "standard",
        "title": "Getting Started",
        "url-slug": "getting-started",
        "first-published-on": "2019-03-20",
        "last-updated-on": "2019-03-20",
        "meta": {
            "title": "Getting Started",
            "description": "Getting started post."
        },
        "excerpt": "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt",
        "path": "2019/03/20/GettingStarted.md"
    }]

Я бы хотел сгруппировать их по тегам в форме ниже:

[{
   "tag1": [{...}, {...}], 
   "tag2": [{...}, {...}], 
   "tag3": [{...}]
}]

Я пытался сделать этоиспользуя lodash:

const groupedByTag = _.groupBy(blogMetadata, function(postmetadata) {
        postmetadata.tags.map(tag => {
          return tag
        })
      })

Очевидно, что приведенный выше код неверен и не работает.Я посмотрел на связанный пост , не добиваясь большого прогресса.Любая помощь приветствуется.

Ответы [ 2 ]

1 голос
/ 01 апреля 2019

Вы можете использовать reduce & forEach в качестве альтернативы loadash. Внутри функции обратного вызова Reduce итерируйте tags и проверьте в объекте-аккумуляторе, существует ли key с этим именем. Если он существует, нажмите текущий объект, иначе создайте key и нажмите value

let data = [{
  "published": true,
  "tags": ["tag1", "tag2"],
  "categories": ["cat1"],
  "author": "some name",
  "post-format": "standard",
  "title": "Second Post,",
  "url-slug": "second-post",
  "first-published-on": "2019-03-28",
  "last-updated-on": "2019-03-28",
  "meta": {
    "title": "Second Post",
    "description": "Second post."
  },
  "excerpt": "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt",
  "path": "2019/03/28/SecondPost.md"
}, {
  "published": true,
  "tags": ["tag1", "tag2", "tag3"],
  "categories": ["cat1", "cat2"],
  "author": "some name",
  "post-format": "standard",
  "title": "Getting Started",
  "url-slug": "getting-started",
  "first-published-on": "2019-03-20",
  "last-updated-on": "2019-03-20",
  "meta": {
    "title": "Getting Started",
    "description": "Getting started post."
  },
  "excerpt": "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt",
  "path": "2019/03/20/GettingStarted.md"
}];

let newMapped = [data.reduce(function(acc, curr) {
  curr.tags.forEach(function(item) {
    if (acc[item]) {
      acc[item].push(curr)
    } else {
      acc[item] = [curr]
    }

  })
  return acc;
}, {})];


console.log(newMapped)
1 голос
/ 01 апреля 2019

Вы можете использовать уменьшить и forEach

Здесь идея

  • Сначала мы перебираем каждый элемент переменной obj.
  • Для каждого элемента мы проходим через свойство tags.
  • Мы проверяем, если op уже имеет этот тег, мы нажимаем значение, иначе мы добавляем новый ключ к op объекту с соответствующим значением

let obj = [{"published": true,"tags": ["tag1", "tag2"],"categories": ["cat1"],"author": "some name","post-format": "standard","title": "Second Post,","url-slug": "second-post","first-published-on": "2019-03-28","last-updated-on": "2019-03-28","meta": {"title": "Second Post","description": "Second post."},"excerpt": "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt","path": "2019/03/28/SecondPost.md"}, {"published": true,"tags": ["tag1", "tag2", "tag3"],"categories": ["cat1", "cat2"],"author": "some name","post-format": "standard","title": "Getting Started","url-slug": "getting-started","first-published-on": "2019-03-20","last-updated-on": "2019-03-20","meta": {"title": "Getting Started","description": "Getting started post."},"excerpt": "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt","path": "2019/03/20/GettingStarted.md"}]

let final = obj.reduce((op,inp) => {
  inp.tags.forEach(e => {
    op[e] = op[e] || []
    op[e].push(JSON.parse(JSON.stringify(inp)))
  }) 
  return op
},{})

console.log(final)
...