Наповнення JS розділу

Добридень, Пані та Панове, завдяки вам вдалося зібрати більше 19тис грн з необхідних 15тис на впровадження JS розділу.

JS розділ вже впроваджено - переходимо до його наповнення і почнемо бігти довгий марафон, адже JS має більше 1100 різноманітних методів, властивостей, подій і т.д., які необхідно описати.

Будемо працювати, і вдень, і вночі, щоб орієнтовно взимку закінчити наповнювати JS розділ!

Ви також можете допомогти нам в цьому. Долучайтеся до нашої спільноти в дискорді - ставайте її частиною і допомагайте нашому розвитку.

Також, підтримуйте нас матеріально.

JS властивість Element.outerHTML

Загальний опис

outerHTML - це властивість об'єкта Element, яка представляє розмітку HTML елемента, включно з самим елементом та його вмістом. Ця властивість дозволяє отримати або встановити HTML-код елемента, що може бути корисним для динамічної маніпуляції вмістом сторінки.

Для отримання HTML-коду елемента достатньо звернутися до властивості outerHTML відповідного об'єкта Element. Наприклад, для елемента з id="myElement" можна використати const html = document.getElementById("myElement").outerHTML;. Це поверне рядок, що містить HTML-код елемента та його вміст.

Властивість outerHTML часто використовується для динамічного оновлення вмісту веб-сторінки без необхідності повного перезавантаження. Наприклад, можна змінити вміст елемента на основі даних, отриманих з серверу:

fetch("/data.json")
  .then(response => response.json())
  .then(data => {
    const element = document.getElementById("myElement");
    element.outerHTML = `<div id="myElement">${data.content}</div>`;
  });

У цьому прикладі ми отримуємо дані з серверу за допомогою fetch, а потім замінюємо весь HTML-код елемента myElement новим вмістом, використовуючи властивість outerHTML.

Крім того, outerHTML можна використовувати для клонування елементів на сторінці. Наприклад, можна створити копію елемента та вставити її в інше місце:

const originalElement = document.getElementById("myElement");
const clone = document.createElement("div");
clone.outerHTML = originalElement.outerHTML;
document.body.appendChild(clone);

У цьому прикладі ми створюємо новий порожній елемент div, копіюємо HTML-код оригінального елемента myElement у властивість outerHTML нового елемента, а потім додаємо його до document.body.

Варто зазначити, що встановлення outerHTML замінює весь елемент, включно з його вмістом та обробниками подій. Тому, якщо ви додали обробники подій до елемента, вони будуть втрачені після заміни outerHTML. У такому випадку краще використовувати властивість innerHTML для заміни лише вмісту елемента.

Підсумовуючи, outerHTML є потужною властивістю для динамічної маніпуляції HTML-кодом елементів на веб-сторінці. Її можна використовувати для отримання або встановлення HTML-коду елемента, оновлення вмісту сторінки без перезавантаження, клонування елементів та інших операцій, пов'язаних з розміткою.

Порада:

Будь обережним при встановленні outerHTML, оскільки це замінює весь елемент, включно з його обробниками подій. Якщо ти додав обробники подій до елемента, вони будуть втрачені після заміни outerHTML. У такому випадку краще використовувати властивість innerHTML для заміни лише вмісту елемента.

Порада:

Використовуй outerHTML для клонування елементів на сторінці. Можна створити копію елемента та вставити її в інше місце, скопіювавши HTML-код оригінального елемента у властивість outerHTML нового елемента.

const originalElement = document.getElementById("myElement");
const clone = document.createElement("div");
clone.outerHTML = originalElement.outerHTML;
document.body.appendChild(clone);
Порада:

Пам'ятай, що outerHTML повертає рядок, що містить HTML-код елемента. Якщо ти плануєш маніпулювати цим рядком або вставляти його в інші частини коду, переконайся, що ти належним чином екрануєш спеціальні символи, щоб уникнути проблем з безпекою або неочікуваної поведінки. Використовуй функції, такі як Node.textContent або Element.innerHTML, якщо тобі потрібно лише отримати або встановити текстовий вміст елемента без розмітки HTML.

Синтаксис

Element.outerHTML

Значення

Return

Переглядачі

Переглядач

1

11

1.3

8

12

Переглядач

1

18

14

1

Переглядач

-

-

Приклади


У цьому прикладі ми маємо елемент div з id="container", що містить початкову розмітку. Також є текстове поле textarea та кнопка "Оновити розмітку".

При завантаженні сторінки ми встановлюємо початкову розмітку елемента #container в текстове поле за допомогою властивості outerHTML. Коли користувач натискає кнопку "Оновити розмітку", ми оновлюємо розмітку елемента #container, присвоюючи його властивості outerHTML значення з текстового поля. Таким чином, користувач може редагувати розмітку в текстовому полі та бачити результат змін безпосередньо на сторінці після натискання кнопки "Оновити розмітку".

Цей приклад демонструє використання властивості outerHTML для отримання та встановлення розмітки елемента, включно з самим елементом. Користувач може взаємодіяти з прикладом, редагуючи розмітку в текстовому полі та оновлюючи її на сторінці.

У цьому прикладі демонструється використання властивості outerHTML для отримання HTML-коду елемента div з id="myDiv" разом з його вмістом. При натисканні на кнопку "Показати outerHTML" викликається функція showOuterHTML(), яка отримує елемент div за допомогою document.getElementById('myDiv'), зчитує значення властивості outerHTML цього елемента та виводить його у елемент <p> на сторінці. Виведений рядок буде містити повний HTML-код елемента div та його вміст.

<div id="myDiv">
  <p>Це параграф всередині div.</p>
</div>
<button onclick="showOuterHTML()">Показати outerHTML</button>
<p id="output"></p>

<script>
function showOuterHTML() {
  const myDiv = document.getElementById('myDiv');
  const outerHTML = myDiv.outerHTML;
  const output = document.getElementById('output');
  output.textContent = outerHTML;
}
<script>

У цьому прикладі демонструється використання властивості outerHTML для зміни HTML-коду елемента списку. На сторінці є невпорядкований список (<ul>) з трьома елементами (<li>). При натисканні на кнопку "Змінити список" викликається функція modifyList(), яка виконує два кроки:

  1. Створюється новий елемент списку (<li>) за допомогою document.createElement('li'), його текстовий вміст встановлюється на "Новий елемент", і він додається до кінця списку за допомогою list.appendChild(newItem).

  2. Отримується другий елемент списку за допомогою list.children[1], і його outerHTML змінюється на нове значення '<li>Змінений елемент</li>'. Це ефективно замінює весь HTML-код другого елемента списку на нове значення.

Після виконання функції modifyList() список буде змінено: до нього буде додано новий елемент у кінці, а другий елемент буде замінено на "Змінений елемент".

<ul id="list">
  <li>Елемент 1</li>
  <li>Елемент 2</li>
  <li>Елемент 3</li>
</ul>
<button onclick="modifyList()">Змінити список</button>

<script>
function modifyList() {
  const list = document.getElementById('list');
  const newItem = document.createElement('li');
  newItem.textContent = 'Новий елемент';

  // Додаємо новий елемент до списку
  list.appendChild(newItem);

  // Змінюємо outerHTML другого елемента списку
  const secondItem = list.children[1];
  secondItem.outerHTML = '<li>Змінений елемент</li>';
}
<script>