Как создать элемент html с помощью js
Перейти к содержимому

Как создать элемент html с помощью js

  • автор:

Изменение документа

Модификации DOM – это ключ к созданию «живых» страниц.

Здесь мы увидим, как создавать новые элементы «на лету» и изменять уже существующие.

Пример: показать сообщение

Рассмотрим методы на примере – а именно, добавим на страницу сообщение, которое будет выглядеть получше, чем alert .

 .alert 
Всем привет! Вы прочитали важное сообщение.

Это был пример HTML. Теперь давайте создадим такой же div , используя JavaScript (предполагаем, что стили в HTML или во внешнем CSS-файле).

Создание элемента

DOM-узел можно создать двумя методами:

Создаёт новый элемент с заданным тегом:

let div = document.createElement('div');

document.createTextNode(text)

Создаёт новый текстовый узел с заданным текстом:

let textNode = document.createTextNode('А вот и я');

Большую часть времени нам нужно создавать узлы элементов, такие как div для сообщения.

Создание сообщения

В нашем случае сообщение – это div с классом alert и HTML в нём:

let div = document.createElement('div'); div.className = "alert"; div.innerHTML = "Всем привет! Вы прочитали важное сообщение.";

Мы создали элемент, но пока он только в переменной. Мы не можем видеть его на странице, поскольку он не является частью документа.

Методы вставки

Чтобы наш div появился, нам нужно вставить его где-нибудь в document . Например, в document.body .

Для этого есть метод append , в нашем случае: document.body.append(div) .

Вот полный пример:

 .alert  

Вот методы для различных вариантов вставки:

  • node.append(. nodes or strings) – добавляет узлы или строки в конец node ,
  • node.prepend(. nodes or strings) – вставляет узлы или строки в начало node ,
  • node.before(. nodes or strings) –- вставляет узлы или строки до node ,
  • node.after(. nodes or strings) –- вставляет узлы или строки после node ,
  • node.replaceWith(. nodes or strings) –- заменяет node заданными узлами или строками.

Вот пример использования этих методов, чтобы добавить новые элементы в список и текст до/после него:

Наглядная иллюстрация того, куда эти методы вставляют:

Итоговый список будет таким:

Эти методы могут вставлять несколько узлов и текстовых фрагментов за один вызов.

Например, здесь вставляется строка и элемент:

Привет

', document.createElement('hr'));

Весь текст вставляется как текст.

Поэтому финальный HTML будет:

<p>Привет</p> 

Другими словами, строки вставляются безопасным способом, как делает это elem.textContent .

Поэтому эти методы могут использоваться только для вставки DOM-узлов или текстовых фрагментов.

А что, если мы хотим вставить HTML именно «как html», со всеми тегами и прочим, как делает это elem.innerHTML ?

insertAdjacentHTML/Text/Element

С этим может помочь другой, довольно универсальный метод: elem.insertAdjacentHTML(where, html) .

Первый параметр – это специальное слово, указывающее, куда по отношению к elem производить вставку. Значение должно быть одним из следующих:

  • "beforebegin" – вставить html непосредственно перед elem ,
  • "afterbegin" – вставить html в начало elem ,
  • "beforeend" – вставить html в конец elem ,
  • "afterend" – вставить html непосредственно после elem .

Второй параметр – это HTML-строка, которая будет вставлена именно «как HTML».

Привет

'); div.insertAdjacentHTML('afterend', '

Пока

');

Привет

Так мы можем добавлять произвольный HTML на страницу.

Мы можем легко заметить сходство между этой и предыдущей картинкой. Точки вставки фактически одинаковые, но этот метод вставляет HTML.

У метода есть два брата:

  • elem.insertAdjacentText(where, text) – такой же синтаксис, но строка text вставляется «как текст», вместо HTML,
  • elem.insertAdjacentElement(where, elem) – такой же синтаксис, но вставляет элемент elem .

Они существуют, в основном, чтобы унифицировать синтаксис. На практике часто используется только insertAdjacentHTML . Потому что для элементов и текста у нас есть методы append/prepend/before/after – их быстрее написать, и они могут вставлять как узлы, так и текст.

Так что, вот альтернативный вариант показа сообщения:

 .alert  

Удаление узлов

Для удаления узла есть методы node.remove() .

Например, сделаем так, чтобы наше сообщение удалялось через секунду:

 .alert  

Если нам нужно переместить элемент в другое место – нет необходимости удалять его со старого.

Все методы вставки автоматически удаляют узлы со старых мест.

Например, давайте поменяем местами элементы:

Клонирование узлов: cloneNode

Как вставить ещё одно подобное сообщение?

Мы могли бы создать функцию и поместить код туда. Альтернатива – клонировать существующий div и изменить текст внутри него (при необходимости).

Иногда, когда у нас есть большой элемент, это может быть быстрее и проще.

  • Вызов elem.cloneNode(true) создаёт «глубокий» клон элемента – со всеми атрибутами и дочерними элементами. Если мы вызовем elem.cloneNode(false) , тогда клон будет без дочерних элементов.

Пример копирования сообщения:

 .alert 
Всем привет! Вы прочитали важное сообщение.

DocumentFragment

DocumentFragment является специальным DOM-узлом, который служит обёрткой для передачи списков узлов.

Мы можем добавить к нему другие узлы, но когда мы вставляем его куда-то, он «исчезает», вместо него вставляется его содержимое.

 return fragment; > ul.append(getListContent()); // (*) 

Обратите внимание, что на последней строке с (*) мы добавляем DocumentFragment , но он «исчезает», поэтому структура будет:

DocumentFragment редко используется. Зачем добавлять элементы в специальный вид узла, если вместо этого мы можем вернуть массив узлов? Переписанный пример:

 return result; > ul.append(. getListContent()); // append + оператор ". " = друзья! 

Мы упоминаем DocumentFragment в основном потому, что он используется в некоторых других областях, например, для элемента template, который мы рассмотрим гораздо позже.

Устаревшие методы вставки/удаления

Старая школа
Эта информация помогает понять старые скрипты, но не нужна для новой разработки.

Есть несколько других, более старых, методов вставки и удаления, которые существуют по историческим причинам.

Сейчас уже нет причин их использовать, так как современные методы append , prepend , before , after , remove , replaceWith более гибкие и удобные.

Мы упоминаем о них только потому, что их можно найти во многих старых скриптах:

Добавляет node в конец дочерних элементов parentElem .

parentElem.insertBefore(node, nextSibling)

Вставляет node перед nextSibling в parentElem .

Чтобы вставить newLi в начало, мы можем сделать вот так:

list.insertBefore(newLi, list.firstChild);

parentElem.replaceChild(node, oldChild)

Заменяет oldChild на node среди дочерних элементов parentElem .

Удаляет node из parentElem (предполагается, что он родитель node ).

Все эти методы возвращают вставленный/удалённый узел. Другими словами, parentElem.appendChild(node) вернёт node . Но обычно возвращаемое значение не используют, просто вызывают метод.

Несколько слов о «document.write»

Есть ещё один, очень древний метод добавления содержимого на веб-страницу: document.write .

Где-то на странице.

Конец

Вызов document.write(html) записывает html на страницу «прямо здесь и сейчас». Строка html может быть динамически сгенерирована, поэтому метод достаточно гибкий. Мы можем использовать JavaScript, чтобы создать полноценную веб-страницу и записать её в документ.

Этот метод пришёл к нам со времён, когда ещё не было ни DOM, ни стандартов… Действительно старые времена. Он всё ещё живёт, потому что есть скрипты, которые используют его.

В современных скриптах он редко встречается из-за следующего важного ограничения:

Вызов document.write работает только во время загрузки страницы.

Если вызвать его позже, то существующее содержимое документа затрётся.

Через одну секунду содержимое этой страницы будет заменено.

Так что после того, как страница загружена, он уже непригоден к использованию, в отличие от других методов DOM, которые мы рассмотрели выше.

Это его недостаток.

Есть и преимущество. Технически, когда document.write запускается во время чтения HTML браузером, и что-то пишет в документ, то браузер воспринимает это так, как будто это изначально было частью загруженного HTML-документа.

Поэтому он работает невероятно быстро, ведь при этом нет модификации DOM. Метод пишет прямо в текст страницы, пока DOM ещё в процессе создания.

Так что, если нам нужно динамически добавить много текста в HTML, и мы находимся на стадии загрузки, и для нас очень важна скорость, это может помочь. Но на практике эти требования редко сочетаются. И обычно мы можем увидеть этот метод в скриптах просто потому, что они старые.

Итого

  • Методы для создания узлов:
    • document.createElement(tag) – создаёт элемент с заданным тегом,
    • document.createTextNode(value) – создаёт текстовый узел (редко используется),
    • elem.cloneNode(deep) – клонирует элемент, если deep==true , то со всеми дочерними элементами.
    • node.append(. nodes or strings) – вставляет в node в конец,
    • node.prepend(. nodes or strings) – вставляет в node в начало,
    • node.before(. nodes or strings) – вставляет прямо перед node ,
    • node.after(. nodes or strings) – вставляет сразу после node ,
    • node.replaceWith(. nodes or strings) – заменяет node .
    • node.remove() – удаляет node .
    • parent.appendChild(node)
    • parent.insertBefore(node, nextSibling)
    • parent.removeChild(node)
    • parent.replaceChild(newElem, node)

    Все эти методы возвращают node .

    • "beforebegin" – вставляет html прямо перед elem ,
    • "afterbegin" – вставляет html в elem в начало,
    • "beforeend" – вставляет html в elem в конец,
    • "afterend" – вставляет html сразу после elem .

    Также существуют похожие методы elem.insertAdjacentText и elem.insertAdjacentElement , они вставляют текстовые строки и элементы, но они редко используются.

    • document.write(html)

    После загрузки страницы такой вызов затирает документ. В основном встречается в старых скриптах.

    Как создать элемент html с помощью js

    JavaScript предоставляет ряд методов для управления элементами на веб-страницы. В частности, мы можем создавать и добавлять новые элементы или заменять и удалять уже имеющиеся. Рассмотрим эти методы.

    Создание элементов

    Для создания элементов объект document имеет следующие методы:

    • createElement(elementName) : создает элемент html, тег которого передается в качестве параметра. Возвращает созданный элемент
    • createTextNode(text) : создает и возвращает текстовый узел. В качестве параметра передается текст узла.

    Создадим элемент с помощью createElement :

    const header = document.createElement("h1"); // создаем заголовок console.log(header); //

    Таким образом, переменная header будет хранить ссылку на элемент h1 .

    Создадим текстовый узел с помощью createTextNode :

    const headerText = document.createTextNode("Hello World"); // создаем текстовый узел console.log( headerText); // "Hello World"

    Добавление элементов

    Однако одного создания элементов недостаточно, их еще надо добавить на веб-страницу.

    Для добавления элементов мы можем использовать один из методов объекта Node:

    • appendChild(newNode) : добавляет новый узел newNode в конец коллекции дочерних узлов
    • insertBefore(newNode, referenceNode) : добавляет новый узел newNode перед узлом referenceNode
    appendChild

    Используем метод appendChild() :

    const header = document.createElement("h1"); // создаем заголовок 

    const headerText = document.createTextNode("Hello World"); // создаем текстовый узел header.appendChild( headerText); // добавляем в элемент h1 текстовый узел console.log(header); //

    Hello World

    И чтобы добавить созданный элемент на страницу, его надо добавить в уже имеющийся на странице элемент:

        METANIT.COM      

    Сначала создаем обычный элемент заголовка h2 и текстовый узел. Затем текстовый узел добавляем в элемент заголовка. Затем заголовок добавляем в элемент body :

    Добавление элемента на веб-страницу в JavaScript

    Стоит отметить, что нам необязательно для определения текста внутри элемента создавать дополнительный текстовый узел, так как мы можем воспользоваться свойством textContent и напрямую ему присвоить текст:

    const header = document.createElement("h1"); // создаем заголовок header.textContent = "Hello World"; // определяем текст элемента

    В этом случае текстовый узел будет создан неявно при установке текста.

    insertBefore

    Метод appendChild() добавляет элемент в конец контейнера. Чтобы более конкретизировать место для добавления, можно использовать другой метод - insertBefore() , который добавляет один элемент перед другим элементом. Например, у нас есть следующая страница:

        METANIT.COM  

    Text 1

    Text 2

    Допустим, нам надо добавить в элемент body перед первым параграфом заголовок. Мы можем сделать это так:

        METANIT.COM  

    Text 1

    Text 2

    Добавление элемента на веб-страницу в JavaScript с помощью метода insertBefore

    Если нам надо вставить новый узел на второе, третье или любое другое место, то нам надо найти узел, перед которым надо вставлять, с помощью комбинаций свойств firstElementChild/lastElementChild и nextSibling/previousSibling.

    Копирование элемента

    Иногда элементы бывают довольно сложными по составу, и гораздо проще их скопировать, чем с помощью отдельных вызовов создавать из содержимое. Для копирования уже имеющихся узлов у объекта Node можно использовать метод cloneNode() :

        METANIT.COM   

    Home Page

    Text 1

    Text 2

    В метод cloneNode() в качестве параметра передается логическое значение: если передается true, то элемент будет копироваться со всеми дочерними узлами; если передается false - то копируется без дочерних узлов. То есть в данном случае мы копируем узел со всем его содержимым и потом добавляем в конец элемента c .

    Клонирование элементов веб-страницы в JavaScript

    Замена элемента

    Для замены элемента применяется метод replaceChild(newNode, oldNode) объекта Node. Этот метод в качестве первого параметра принимает новый элемент, который заменяет старый элемент oldNode, передаваемый в качестве второго параметра.

        METANIT.COM   

    Home Page

    Text 1

    Text 2

    В данном случае заменяем первый элемент - первый параграф заголовком h2:

    Замена элемента веб-страницы в JavaScript

    Удаление элемента

    Для удаления элемента вызывается метод removeChild() объекта Node. Этот метод удаляет один из дочерних узлов:

        METANIT.COM   

    Home Page

    Text 1

    Text 2

    В данном случае удаляется первый параграф из блока div

    Удаление всех элементов

    Иногда возникает необходимость удалить все элементы. Для этого перебираем все элементы контейнера и удаляем их:

    Home Page

    Text 1

    Text 2

    const article = document.getElementById("article"); while(article.firstChild)

    Как добавить элемент в html через js

    Добавить элемент в html через js можно с помощью метода document.createElement() . Предположим, что у нас есть следующий html документ:

     class="container">

Внутрь данного контейнера мы хотим поместить заголовок первого уровня красного цвета с надписью Hello, World!

// получаем контейнер const container = document.querySelector('.container'); // создаем новый элемент - заголовок первого уровня const h1 = document.createElement('h1'); // добавляем класс .red, в котором указан нужный нам цвет текста h1.classList.add('red'); // добавляем нужный текст h1.textContent = 'Hello, World!'; // кладем заголовок в контейнер container.append(h1); 

Метод createElement()

HTML элементы часто содержат текст. Чтобы создать кнопку с текстом, используйте свойства innerText или innerHTML объекта элемента:

Пример

Создать элемент button с текстом:

var btn = document.createElement("BUTTON"); // Создать элемент
btn.innerHTML = "НАЖМИТЕ НА МЕНЯ"; // Вставить текст
document.body.appendChild(btn); // Добавить к

НАЖМИТЕ НА МЕНЯ

Еще примеры "Попробуй сам" ниже.

Определение и использование

Метод createElement() создает узел элемента с указанным именем.

Совет: После создания элемента, используйте метод element.appendChild() или element.insertBefore() метод вставки его в документ.

Поддержка браузера

Метод
createElement() Да Да Да Да Да

Синтаксис

document.createElement(nodename)

Параметр значений

Параметр Тип Описание
nodename Строка Требуемый. Имя элемента, который вы хотите создать

Технические детали

Возвращаемое значение: Объект элемента, представляющий созданный узел элемента
Версия DOM Основной уровень 1 Объект документа

Еще примеры

Пример

Создать элемент

с некоторым текстом, используйте innerText для установки текста и добавьте его в документ:

var para = document.createElement("P"); // Создайте элемент

para.innerText = "Это параграф"; // Вставить текст
document.body.appendChild(para); // Добавить

к

Пример

Создать элемент

и добавьте его к элементу :

Упражнения
КАК СДЕЛАТЬ
ПОДЕЛИТЬСЯ
СЕРТИФИКАТЫ

Сообщить об ошибке

Если вы хотите сообщить об ошибке или сделать предложение, не стесняйтесь, присылайте нам электронное письмо:

Ваше предложение:

Спасибо, за вашу помощь!

Ваше сообщение было отправлено в SchoolsW3.

Топ Учебники
Топ Справочники
Топ Примеры
Веб Сертификаты

SchoolsW3 оптимизирован для обучения, тестирования и тренировки. Примеры упрощают и улучшают чтение и базовое понимание.Учебники, справочники, примеры постоянно пересматриваются, для того, чтобы избежать ошибки, невозможно гарантировать правильность всего содержимого.Используя данный сайт, вы соглашаетесь прочитать и принять условия использования, cookie и Политика конфиденциальности.Авторское право 1999 - 2022 Все права защищены.
Работает на W3.CSS.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *