Задать вопрос
@sidorchik

Как вывести массив ссылок, добавив заголовки?

Есть массив со ссылками на страницы. Каждая ссылка относится к категории, например Cats.
const list = [
	{
		title: 'Link 1',
		part: 'Cats'
	},
	{
		title: 'Link 2',
		part: 'Cats'
	},
	{
		title: 'Link 3',
		part: 'Dogs'
	},
	{
		title: 'Link 4',
		part: 'Dogs'
	}
];

Как вывести ссылки с написанными перед ними заголовками категорий? Нужно, чтобы категория выводилась один раз.
<div>Cats</div>
<div>Link 1</div>
<div>Link 2</div>
<div>Dogs</div>
<div>Link 3</div>
<div>Link 4</div>

Я написал такой вывод с указанием начала категории, но это не гибкое решение. Подскажите, пожалуйста, как сделать хорошо.

Можно и не выводить данные, просто логировать. Потом всё равно перенесу в Реакт.
  • Вопрос задан
  • 165 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 2
0xD34F
@0xD34F Куратор тега JavaScript
Сначала группируете данные:

const grouped = Object.entries(list.reduce((acc, n) => (
  (acc[n.part] = acc[n.part] || []).push(n.title),
  acc
), {}));

Потом можно html собрать:

document.body.insertAdjacentHTML('beforeend', grouped
  .map(([ k, v ]) => `<div>${k}</div>${v.map(n => `<div>${n}</div>`).join('')}`)
  .join('')
);

Или создать элементы напрямую:

document.body.append(...grouped.flat(2).map(n => {
  const div = document.createElement('div');
  div.innerText = n;
  return div;
}));
Ответ написан
@StockholmSyndrome
const data = list.reduce((acc, {title, part}) => {
  acc[part] = acc[part] || [];
  acc[part].push(title); 
  return acc;
}, {});


Object.entries(data).forEach(([part, titles]) => {
  [part, ...titles].forEach((item) => {
    const div = document.createElement('div'); 
    div.textContent = item; 
    document.body.appendChild(div);
  });
});
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы