JavaScript/DOM/Document/createElement

Aus SELFHTML-Wiki
< JavaScript‎ | DOM‎ | Document
Wechseln zu: Navigation, Suche

Die Methode Document.createElement() erzeugt ein neues Element für den Elementbaum. Sie lässt sich auf HTML-, aber auch auf XML-Dokumente anwenden.


Syntax

let element = Document.createElement(tagName)

  • tagName: Name des Elements, das erzeugt werden soll (als Zeichenkette)


Anwendungsbeispiele

Überschrift erzeugen

Überschrift dynamisch erzeugen ansehen …
   function addNewHeading() {
      const h2 = document.createElement('h2');
      h2.id = 'dynamic';
// oder:  h2.setAttribute('id', 'dynamic');
      h2.textContent = 'Eine sehr dynamische Seite';
      
      document.getElementById('main').appendChild(h2);
   }

   document
      .getElementById('addHeading')
      .addEventListener ('click', addNewHeading);

Das Beispiel enthält einen main-Bereich, der zunächst bis auf den button leer ist.

Das Script registriert mit addEventListener einen Handler für das click-Event: die Funktion addNewHeading.

Wenn Sie nun auf den Button klicken, wird mit document.createElement("h2") ein neues Element vom Typ h2 erzeugt (also eine HTML-Überschrift zweiter Ordnung) und in einer Variablen namens h2 gespeichert. Die Überschrift wird damit aber noch nicht angezeigt - denn createElement stellt sie nur als neues Objekt bereit, hängt sie aber nicht automatisch in den Elementbaum des Dokuments.

Über die Variable h2 kann das neu erzeugte Element nun weiter bearbeitet werden. Und zwar sollen noch zwei Dinge geschehen: zum einen soll die Überschrift ein id-Attribut mit dem Wert 'dynamic' erhalten, zum anderen soll auch Text hinein. Das id-Attribut könnte mit Hilfe der setAttribute()-Methode gesetzt werden; diese Möglichkeit befindet sich auskommentiert im Beispiel.

Für die ID eines Elements stellt die HTMLElement-Schnittstelle aber mit der Objekteigenschaft ideine einfachere Möglichkeit bereit. Als zweites soll die Überschrift einen Text zugewiesen bekommen. Dafür ist es am einfachsten, diesen Text der Eigenschaft textContent zuzuweisen, die jeder Elementknoten im DOM besitzt. Statt dessen könnte man auch mit Hilfe der createTextNode()-Methode einen Textknoten erzeugen und mit appendChild() der Überschrift hinzufügen, aber die textContent-Eigenschaft übernimmt das für uns.

Nachdem das h2-Objekt fertig vorbereitet ist, kann es in den vorhandenen Elementbaum eingehängt werden. Dazu sucht sich das Script das <main>-Element heraus und fügt ihm mit der Methode appendChild() die Überschrift hinzu. Die Überschrift wird dadurch zum letzten Element im main-Element, befindet sich also unter dem Button.

Um ein H2-Element mit ID und Textinhalt ans Ende des main-Elements einzufügen, hätte man hier auch die Methode insertAdjacentHTML verwenden können.

Beispiel
  document.getElementById('main')
          .insertAdjacentHTML('beforeend', '<h2 id="dynamic">Eine sehr dynamische Seite</h2>');

Allerdings ist hier auf Kontextwechsel und richtige Schachtelung von Anführungszeichen achtzugeben. Einen Attributwert mit einem Anführungszeichen darin kann man mit setAttribute problemlos setzen, einen Textinhalt mit spitzen Klammern oder &-Zeichen auch, aber wenn man HTML direkt einsetzt, muss man darauf achten, solche Zeichen zu maskieren.

Primitiver Website-Builder

Primitiver Website-Builder ansehen …
document.addEventListener('DOMContentLoaded', function () {
  const form = document.querySelector('form');
  const addButton = document.querySelector('#add');
  const elementType = document.querySelector('#elementType');
  const contentInput = document.querySelector('#content');
  const resultContainer = '#result';

  addButton.addEventListener('click', function () {
    const element = elementType.value; 
    const content = contentInput.value.trim(); 

    if (content === '' && element !== 'hr') {
      alert('Bitte einen Inhalt für das Element eingeben.');
      return;
    }

    createElement(resultContainer, element, content);

    // Eingabefeld wieder leeren
    contentInput.value = '';
  });
  
  // Helfer-Funktion, um HTML-Elemente zu erzeugen
  function createElement(parent, elem, content, attributes = {}) {
    const container = document.querySelector(parent);
    
    if (!container) {
      console.error(`Parent element "${parent}" not found.`);
      return;
    }

    if (typeof elem !== 'string') {
      console.error(`Invalid element type: ${elem}`);
      return;
    }

    const newElm = document.createElement(elem);
    newElm.textContent = content;

    // Apply optional attributes
    for (let [key, value] of Object.entries(attributes)) {
      newElm.setAttribute(key, value);
    }

    container.appendChild(newElm);
  }  
  
});

Das Beispiel verwendet die Helfer-Funktion aus dem DOM-Tutorial.

Das Beispiel enthält im sichtbaren HTML-Bereich ein Formular mit einer Auswahlliste, einem Eingabefeld und einem Klick-Button. Unterhalb ist noch ein div-Bereich notiert, der jedoch noch keinen konkreten Inhalt hat.

In der Auswahlliste des Formulars kann der Anwender einen HTML-Elementtyp auswählen – in den value-Attributen der option-Elemente sind die tatsächlichen HTML-Elementnamen der jeweiligen Auswahl gespeichert. Im Eingabefeld des Formulars kann der Anwender den Textinhalt für das ausgewählte Element eingeben. Wenn er dann auf den Button klickt, werden die Eingaben ausgelesen und als Parameter in die Helfer-Funktion createElement() eingegeben.

Helfer-Funktion createElement()
  function createElement(parent, elem, content, attributes = {}) {
    const container = document.querySelector(parent);
    
    if (!container) {
      console.error(`Parent element "${parent}" not found.`);
      return;
    }

    if (typeof elem !== 'string') {
      console.error(`Invalid element type: ${elem}`);
      return;
    }

    const newElm = document.createElement(elem);
    newElm.textContent = content;

    // Apply optional attributes
    for (let [key, value] of Object.entries(attributes)) {
      newElm.setAttribute(key, value);
    }

    container.appendChild(newElm);
  }  
  
});

Mit document.querySelector(parent) wird das Elternelement gesucht. Fall es nicht vorhanden ist, wird in der Konsole ein Fehler ausgegeben.

Eine ähnliche Abfrage, ob es das zu erzeugende Element überhaupt gibt, wäre hier mit dem option-Menü nicht nötig - die Helfer-Funktion soll aber universell einsetzbar sein!

Mit document.createElement(elem); wird dann ein leeres, neues Element erzeugt, also je nach Wert der Variablen Typ z. B. ein h1-Element oder ein p-Element. Damit wird das Element aber noch nicht angezeigt. document.createElement() erzeugt lediglich den Elementknoten, hängt ihn aber noch nicht in den Strukturbaum des Dokuments ein.

Mit newElm.textContent = content; wird der eingegebene Text als Textknoten erzeugt.

Erst jetzt wird das neue Element mit seinem Textknoten mit der Methode appendChild() ins DOM eingehängt. Anwendbar ist die Methode auf ein Knotenobjekt, das Kindknoten haben darf. Also beispielsweise Elementknoten. Als Parameter erwartet die Methode einen Knoten, der als Kindknoten eingehängt werden soll.

Mit der Anweisung container.appendChild(newElm); wird auf den zunächst leeren div-Bereich im Dokument zugegriffen. Diesem Element wird der neu erzeugte Elementknoten hinzugefügt.

Siehe auch

  • DOM-Manipulation
    • Elemente dynamisch
      • erzeugen
      • entfernen
  • SVG und JavaScript
    • DOM-Scripting mit createElementNS()


Weblinks