Создайте одну таблицу HTML из нескольких массивов

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

Я хотел бы получить что-то вроде этого:

введите сюда описание изображения

Но с моим кодом у меня есть: введите сюда описание изображения

Более того, я не знаю, как добавить среднюю линию и заполнить ее под возрастом, поэтому я попробовал просто указать имя и возраст, чтобы сделать это проще. Если кто-то может мне помочь :)

ЯС:

let names = ["X","Y"]
let ages = [22,10]

const newTable = document.createElement("table");
    newTable.innerHTML = "<thead><th>Name</th><th>Index</th></thead>";
    for (let name of names) {

      let newRow = document.createElement("tr");
      const tdName= document.createElement("td");
      tdName.textContent = name;
      newRow.appendChild(tdName);
      newTable.appendChild(newRow);
    }

    for (let age of ages ) {

      let newRow = document.createElement("tr");
      const tdAge= document.createElement("td");
      tdAge.textContent = String(age);
      newRow.appendChild(tdAge);
      newTable.appendChild(newRow);
    }

    const target = document.getElementById('target');
    target.appendChild(newTable);
  }

HTML:

<div id = "target"></div>

Вы создаете новую строку для каждого имени и каждого возраста. Я бы перебирал длину (убедившись, что они одинаковы), добавлял строку для каждой итерации, а затем добавлял ячейку для каждого массива.

mykaf 23.02.2024 17:32

Спасибо, все работает хорошо. Я обновил пост, чтобы попытаться продвинуть проблему немного дальше, если вы не возражаете?

dev_noob 23.02.2024 18:27

Я действительно думаю, что вам следует принять мой ответ, если он сработал для вас, и создать новый вопрос для этой части, а не перемещать цели исходного вопроса.

mykaf 23.02.2024 18:58
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
3
104
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Не создавайте новую строку для каждого имени и возраста; вам нужна строка для каждого «набора» элементов, поэтому переберите длину (проверяя, совпадают ли они), а затем создайте ячейку для каждого соответствующего элемента массива.

let names = ["X", "Y"]
let ages = [22, 10]

const newTable = document.createElement("table");
newTable.innerHTML = "<thead><th>Name</th><th>Index</th></thead>";

if (names.length == ages.length) {
  for (let i = 0; i < names.length; i++) {

    let newRow = document.createElement("tr");
    //name
    const tdName = document.createElement("td");
    tdName.textContent = names[i];
    newRow.appendChild(tdName);
    //age
    const tdAge = document.createElement("td");
    tdAge.textContent = String(ages[i]);
    newRow.appendChild(tdAge);
    newTable.appendChild(newRow);
  }
}
const target = document.getElementById('target');
target.appendChild(newTable);
<div id = "target"></div>

Другие вопросы по теме