@Andriy022

Почему у меня в HTML пишет [object HTMLDivElement]?

let container = document.createElement('div')
document.body.append(container)

const objRound = obj => {
    let user = document.createElement('div')
    container.append(user)

    for (let key in obj) {
        let content = document.createElement('div')
        user.append(content)
        if (typeof obj[key] === 'object') {
            let arr = document.createElement('div')
            content.append(arr)
            arr.innerText = `${key}: ${objRound(obj[key])}`;
            continue;
        }
        content.innerText = `${key}: ${obj[key]}`;
    }
    return user;
};
fetch(' https://jsonplaceholder.typicode.com/users')
    .then(item => item.json())
    .then(item => {
        item.forEach(e => {
            container.insertAdjacentHTML('beforeEnd', objRound(e));
        });
    })
  • Вопрос задан
  • 647 просмотров
Решения вопроса 1
Aetae
@Aetae Куратор тега JavaScript
Тлен
Потому что user который возвращается из objRound - это dom-элемент div, а insertAdjacentHTML ждёт на вход html-строку.
Используй insertAdjacentElement.
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы
23 нояб. 2024, в 00:16
2000 руб./за проект
22 нояб. 2024, в 23:55
3000 руб./за проект
22 нояб. 2024, в 22:26
3500 руб./за проект