Я пытаюсь создать 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>
Спасибо, все работает хорошо. Я обновил пост, чтобы попытаться продвинуть проблему немного дальше, если вы не возражаете?
Я действительно думаю, что вам следует принять мой ответ, если он сработал для вас, и создать новый вопрос для этой части, а не перемещать цели исходного вопроса.



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Не создавайте новую строку для каждого имени и возраста; вам нужна строка для каждого «набора» элементов, поэтому переберите длину (проверяя, совпадают ли они), а затем создайте ячейку для каждого соответствующего элемента массива.
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>
Вы создаете новую строку для каждого имени и каждого возраста. Я бы перебирал длину (убедившись, что они одинаковы), добавлял строку для каждой итерации, а затем добавлял ячейку для каждого массива.