Erweiterte Textformatierung

Es gibt viele weitere Elemente in HTML zur Textformatierung, die wir im Artikel HTML-Textgrundlagen nicht behandelt haben. Die in diesem Artikel beschriebenen Elemente sind weniger bekannt, aber dennoch nützlich, um sie zu kennen (und dies ist keinesfalls eine vollständige Liste). Hier erfahren Sie, wie man Zitate, Definitionslisten, Computer-Code und andere verwandte Texte, Tief- und Hochstellungen, Kontaktinformationen und mehr auszeichnet.

Voraussetzungen: Grundlegende HTML-Kenntnisse, wie sie in Erste Schritte mit HTML behandelt werden. HTML-Textformatierung, wie sie in HTML-Textgrundlagen behandelt wird.
Ziel: Erlernen, wie man weniger bekannte HTML-Elemente verwendet, um erweiterte semantische Funktionen zu kennzeichnen.

Definitionslisten

In HTML-Textgrundlagen haben wir uns angeschaut, wie man grundlegende Listen in HTML markiert und wir haben die dritte Art von Listen erwähnt, auf die Sie gelegentlich stoßen werden — Definitionslisten. Der Zweck dieser Listen besteht darin, eine Reihe von Elementen und ihre zugehörigen Beschreibungen zu markieren, wie Begriffe und Definitionen oder Fragen und Antworten. Schauen wir uns ein Beispiel für eine Reihe von Begriffen und Definitionen an:

soliloquy
In drama, where a character speaks to themselves, representing their inner thoughts or feelings and in the process relaying them to the audience (but not to other characters.)
monologue
In drama, where a character speaks their thoughts out loud to share them with the audience and any other characters present.
aside
In drama, where a character shares a comment only with the audience for humorous or dramatic effect. This is usually a feeling, thought or piece of additional background information

Definitionslisten verwenden eine andere Hülle als die anderen Listentypen — <dl>; jedes Element wird zusätzlich in ein <dt> (Definitionsterm) Element eingeschlossen, und jede Beschreibung ist in ein <dd> (Definitionsbeschreibung) Element eingeschlossen.

Beispiel für eine Definitionsliste

Lassen Sie uns unser Beispiel fertig auszeichnen:

html
<dl>
  <dt>soliloquy</dt>
  <dd>
    In drama, where a character speaks to themselves, representing their inner
    thoughts or feelings and in the process relaying them to the audience (but
    not to other characters.)
  </dd>
  <dt>monologue</dt>
  <dd>
    In drama, where a character speaks their thoughts out loud to share them
    with the audience and any other characters present.
  </dd>
  <dt>aside</dt>
  <dd>
    In drama, where a character shares a comment only with the audience for
    humorous or dramatic effect. This is usually a feeling, thought, or piece of
    additional background information.
  </dd>
</dl>

Die Standardstile des Browsers zeigen Definitionslisten mit etwas eingerückten Beschreibungen im Vergleich zu den Begriffen an.

Mehrere Beschreibungen für einen Begriff

Beachten Sie, dass es erlaubt ist, ein einzelnes Element mit mehreren Beschreibungen zu haben, zum Beispiel:

html
<dl>
  <dt>aside</dt>
  <dd>
    In drama, where a character shares a comment only with the audience for
    humorous or dramatic effect. This is usually a feeling, thought, or piece of
    additional background information.
  </dd>
  <dd>
    In writing, a section of content that is related to the current topic, but
    doesn't fit directly into the main flow of content so is presented nearby
    (often in a box off to the side.)
  </dd>
</dl>

Aktives Lernen: Ein Satz von Definitionen markieren

Es ist Zeit, Ihr Können an Definitionslisten auszuprobieren; fügen Sie Elemente zum Rohtext im Eingabefeld hinzu, sodass es im Ausgabefeld als Definitionsliste erscheint. Sie können Ihre eigenen Begriffe und Beschreibungen ausprobieren, wenn Sie möchten.

Wenn Sie einen Fehler machen, können Sie ihn jederzeit mit der Zurücksetzen-Schaltfläche zurücksetzen. Wenn Sie wirklich feststecken, drücken Sie die Lösung anzeigen-Schaltfläche, um die Antwort zu sehen.

Zitate

HTML bietet auch Funktionen zum Markieren von Zitaten; welches Element Sie verwenden, hängt davon ab, ob Sie ein Block- oder Inline-Zitat markieren.

Blockzitate

Wenn ein Abschnitt von Blockinhalt (sei es ein Absatz, mehrere Absätze, eine Liste usw.) aus einer anderen Quelle zitiert wird, sollten Sie ihn in ein <blockquote>-Element einfügen, um dies anzuzeigen und eine URL zur Quelle des Zitats in einem cite-Attribut angeben. Zum Beispiel, das folgende Markup ist von der MDN <blockquote>-Element-Seite übernommen:

html
<p>
  The <strong>HTML <code>&lt;blockquote&gt;</code> Element</strong> (or
  <em>HTML Block Quotation Element</em>) indicates that the enclosed text is an
  extended quotation.
</p>

Um dies in ein Blockzitat zu verwandeln, würden wir Folgendes tun:

html
<p>Here is a blockquote:</p>
<blockquote
  cite="https://developer.mozilla.org/en-US/docs/Web/HTML/Element/blockquote">
  <p>
    The <strong>HTML <code>&lt;blockquote&gt;</code> Element</strong> (or
    <em>HTML Block Quotation Element</em>) indicates that the enclosed text is
    an extended quotation.
  </p>
</blockquote>

Die Standardstilgebung des Browsers rendert dies als eingerückten Absatz, als Hinweis darauf, dass es sich um ein Zitat handelt; der Absatz über dem Zitat ist dazu da, dies zu demonstrieren.

Inline-Zitate

Inline-Zitate funktionieren auf genau die gleiche Weise, außer dass sie das <q>-Element verwenden. Zum Beispiel enthält das folgende Markup ein Zitat von der MDN <q>-Seite:

html
<p>
  The quote element — <code>&lt;q&gt;</code> — is
  <q cite="https://developer.mozilla.org/en-US/docs/Web/HTML/Element/q">
    intended for short quotations that don't require paragraph breaks.
  </q>
</p>

Die Standardstilgebung des Browsers rendert dies als normalen Text in Anführungszeichen, um ein Zitat anzuzeigen, etwa so:

Zitationen

Der Inhalt des cite-Attributs klingt nützlich, aber leider tun Browser, Screenreader usw. nicht viel damit. Es gibt keine Möglichkeit, den Inhalt von cite anzuzeigen, ohne eine eigene Lösung mit JavaScript oder CSS zu schreiben. Wenn Sie die Quelle des Zitats auf der Seite verfügbar machen möchten, müssen Sie es im Text über einen Link oder auf eine andere geeignete Weise verfügbar machen.

Es gibt ein <cite>-Element, aber dieses ist dazu gedacht, den Titel der zitierten Ressource zu enthalten, z.B. den Namen des Buches. Es gibt jedoch keinen Grund, warum Sie den Text innerhalb von <cite> nicht auf irgendeine Weise mit der Quelle des Zitats verlinken sollten:

html
<p>
  According to the
  <a href="/en-US/docs/Web/HTML/Element/blockquote">
    <cite>MDN blockquote page</cite></a>:
</p>

<blockquote
  cite="https://developer.mozilla.org/en-US/docs/Web/HTML/Element/blockquote">
  <p>
    The <strong>HTML <code>&lt;blockquote&gt;</code> Element</strong> (or
    <em>HTML Block Quotation Element</em>) indicates that the enclosed text is
    an extended quotation.
  </p>
</blockquote>

<p>
  The quote element — <code>&lt;q&gt;</code> — is
  <q cite="https://developer.mozilla.org/en-US/docs/Web/HTML/Element/q">
    intended for short quotations that don't require paragraph breaks.
  </q>
  — <a href="/en-US/docs/Web/HTML/Element/q"><cite>MDN q page</cite></a>.
</p>

Standardmäßig werden Zitationen in kursiver Schrift angezeigt.

Aktives Lernen: Wer hat das gesagt?

Zeit für ein weiteres aktives Lernbeispiel! In diesem Beispiel möchten wir, dass Sie:

  1. Den mittleren Absatz in ein Blockzitat mit einem cite-Attribut verwandeln.
  2. "The Need To Eliminate Negative Self Talk" im dritten Absatz in ein Inline-Zitat umwandeln und ein cite-Attribut hinzufügen.
  3. Den Titel jeder Quelle in <cite>-Tags einschließen und jeden in einen Link zur jeweiligen Quelle umwandeln.

Die benötigten Zitationsquellen sind:

  • http://www.brainyquote.com/quotes/authors/c/confucius.html für das Konfuzius-Zitat
  • http://example.com/affirmationsforpositivethinking für "The Need To Eliminate Negative Self Talk".

Wenn Sie einen Fehler machen, können Sie ihn jederzeit mit der Zurücksetzen-Schaltfläche zurücksetzen. Wenn Sie wirklich feststecken, drücken Sie die Lösung anzeigen-Schaltfläche, um die Antwort zu sehen.

Abkürzungen

Ein weiteres ziemlich verbreitetes Element, dem Sie im Web begegnen werden, ist <abbr> — es wird verwendet, um eine Abkürzung oder ein Akronym zu kennzeichnen. Wenn Sie entweder die vollständige Entfaltung des Begriffs beim erstmaligen Einsatz im Klartext angeben, sollten Sie das <abbr> zur Kennzeichnung der Abkürzung verwenden. Dies gibt den Nutzeragenten einen Hinweis, wie der Inhalt angekündigt/angezeigt werden soll, während alle Benutzer über die Bedeutung der Abkürzung informiert werden.

Wenn die Bereitstellung der Entfaltung zusätzlich zur Abkürzung wenig Sinn ergibt und es sich bei der Abkürzung oder dem Akronym um eine recht kurze Bezeichnung handelt, geben Sie die vollständige Entfaltung des Begriffs als Wert des title-Attributs an:

Beispiel für Abkürzungen

Schauen wir uns ein Beispiel an.

html
<p>
  We use <abbr>HTML</abbr>, Hypertext Markup Language, to structure our web
  documents.
</p>

<p>
  I think <abbr title="Reverend">Rev.</abbr> Green did it in the kitchen with
  the chainsaw.
</p>

Diese werden in etwa wie folgt angezeigt:

Hinweis: Frühere Versionen von html unterstützten auch das <acronym>-Element, aber es wurde aus der HTML-Spezifikation entfernt zugunsten der Verwendung von <abbr> zur Darstellung von Abkürzungen und Akronymen. <acronym> sollte nicht verwendet werden.

Aktives Lernen: Eine Abkürzung markieren

Für diese einfache aktive Lernaufgabe möchten wir, dass Sie eine Abkürzung kennzeichnen. Sie können unser Beispiel unten verwenden oder es durch ein eigenes ersetzen.

Kontaktinformationen auszeichnen

HTML hat ein Element für das Markieren von Kontaktinformationen — <address>. Dieses umschließt Ihre Kontaktinformationen, zum Beispiel:

html
<address>Chris Mills, Manchester, The Grim North, UK</address>

Es könnte auch komplexere Markups und andere Arten von Kontaktinformationen enthalten, zum Beispiel:

html
<address>
  <p>
    Chris Mills<br />
    Manchester<br />
    The Grim North<br />
    UK
  </p>

  <ul>
    <li>Tel: 01234 567 890</li>
    <li>Email: [email protected]</li>
  </ul>
</address>

Beachten Sie, dass dies ebenfalls in Ordnung wäre, wenn die verlinkte Seite die Kontaktinformationen enthält:

html
<address>
  Page written by <a href="../authors/chris-mills/">Chris Mills</a>.
</address>

Hinweis: Das <address>-Element sollte nur verwendet werden, um Kontaktinformationen für das Dokument bereitzustellen, das im nächstgelegenen <article>- oder <body>-Element enthalten ist. Es wäre korrekt, es im Footer einer Seite zu verwenden, um die Kontaktinformationen der gesamten Seite zu enthalten, oder innerhalb eines Artikels für die Kontaktdaten des Autors, aber nicht, um eine Liste von Adressen zu kennzeichnen, die nicht mit dem Inhalt dieser Seite zusammenhängen.

Hoch- und Tiefstellungen

Gelegentlich müssen Sie Hoch- und Tiefstellungen verwenden, wenn Sie Elemente wie Daten, chemische Formeln und mathematische Gleichungen kennzeichnen, damit sie die richtige Bedeutung haben. Die <sup>- und <sub>-Elemente übernehmen diese Aufgabe. Zum Beispiel:

html
<p>My birthday is on the 25<sup>th</sup> of May 2001.</p>
<p>
  Caffeine's chemical formula is
  C<sub>8</sub>H<sub>10</sub>N<sub>4</sub>O<sub>2</sub>.
</p>
<p>If x<sup>2</sup> is 9, x must equal 3 or -3.</p>

Die Ausgabe dieses Codes sieht folgendermaßen aus:

Repräsentation von Computercode

Es gibt eine Reihe von Elementen zum Markieren von Computercode mit HTML:

  • <code>: Zum Markieren von generischen Codeausschnitten.
  • <pre>: Zum Beibehalten von Leerraum (in der Regel Codeblöcke) — wenn Sie Einrückungen oder überflüssigen Leerraum in Ihrem Text verwenden, ignorieren Browser diese, und Sie sehen sie nicht auf Ihrer gerenderten Seite. Wenn Sie den Text jedoch in <pre></pre>-Tags einfügen, wird Ihr Leerraum identisch wie in Ihrem Texteditor gerendert.
  • <var>: Zum speziell Markieren von Variablennamen.
  • <kbd>: Zum Markieren von Tastatur- (und anderen) Eingaben in den Computer.
  • <samp>: Zum Markieren der Ausgabe eines Computerprogramms.

Schauen wir uns Beispiele dieser Elemente und ihre Verwendung zur Darstellung von Computercode an. Wenn Sie die vollständige Datei sehen möchten, schauen Sie sich die other-semantics.html Beispieldatei an. Sie können die Datei herunterladen und in Ihrem Browser öffnen, um sich selbst ein Bild zu machen, aber hier ist ein Ausschnitt des Codes:

html
<pre><code>const para = document.querySelector('p');

para.onclick = function() {
  alert('Owww, stop poking me!');
}</code></pre>

<p>
  You shouldn't use presentational elements like <code>&lt;font&gt;</code> and
  <code>&lt;center&gt;</code>.
</p>

<p>
  In the above JavaScript example, <var>para</var> represents a paragraph
  element.
</p>

<p>Select all the text with <kbd>Ctrl</kbd>/<kbd>Cmd</kbd> + <kbd>A</kbd>.</p>

<pre>$ <kbd>ping mozilla.org</kbd>
<samp>PING mozilla.org (63.245.215.20): 56 data bytes
64 bytes from 63.245.215.20: icmp_seq=0 ttl=40 time=158.233 ms</samp></pre>

Der obige Code sieht folgendermaßen aus:

Zeiten und Daten markieren

HTML bietet auch das <time>-Element zum Markieren von Zeiten und Daten in einem maschinenlesbaren Format. Zum Beispiel:

html
<time datetime="2016-01-20">20 January 2016</time>

Warum ist das nützlich? Nun, es gibt viele verschiedene Möglichkeiten, wie Menschen Daten aufschreiben. Das obige Datum könnte geschrieben werden als:

  • 20. Januar 2016
  • 20. Januar 2016
  • 20. Jan. 2016
  • 20/01/16
  • 01/20/16
  • Der 20. des nächsten Monats
  • 20e Janvier 2016
  • 2016 年 1 月 20 日
  • Und so weiter

Aber diese verschiedenen Formen können von Computern nicht leicht erkannt werden — was, wenn Sie die Daten aller Ereignisse auf einer Seite automatisch erfassen und in einen Kalender einfügen wollten? Das <time>-Element ermöglicht es Ihnen, eine eindeutige, maschinenlesbare Zeit/Datum für diesen Zweck anzuhängen.

Das grundlegende Beispiel oben bietet einfach ein einfaches maschinenlesbares Datum, aber es gibt viele andere Optionen, die möglich sind, zum Beispiel:

html
<!-- Standard simple date -->
<time datetime="2016-01-20">20 January 2016</time>
<!-- Just year and month -->
<time datetime="2016-01">January 2016</time>
<!-- Just month and day -->
<time datetime="01-20">20 January</time>
<!-- Just time, hours and minutes -->
<time datetime="19:30">19:30</time>
<!-- You can do seconds and milliseconds too! -->
<time datetime="19:30:01.856">19:30:01.856</time>
<!-- Date and time -->
<time datetime="2016-01-20T19:30">7.30pm, 20 January 2016</time>
<!-- Date and time with timezone offset -->
<time datetime="2016-01-20T19:30+01:00">
  7.30pm, 20 January 2016 is 8.30pm in France
</time>
<!-- Calling out a specific week number -->
<time datetime="2016-W04">The fourth week of 2016</time>

Testen Sie Ihre Fähigkeiten!

Sie haben das Ende dieses Artikels erreicht, aber können Sie sich an die wichtigsten Informationen erinnern? Sie finden weitere Tests, um zu überprüfen, ob Sie diese Informationen behalten haben, bevor Sie fortfahren — siehe Test your skills: Advanced HTML text.

Zusammenfassung

Damit endet unser Studium der HTML-Textsemantik. Bedenken Sie, dass das, was Sie in diesem Kurs gesehen haben, keine vollständige Liste von HTML-Text-Elementen ist — wir wollten versuchen, die wesentlichen und einige der häufigsten, die Sie in der freien Wildbahn sehen werden, oder zumindest interessante, abzudecken. Um noch viele weitere HTML-Elemente zu finden, können Sie sich unser HTML-Element-Referenz ansehen (der Abschnitt Inline text semantics wäre ein großartiger Ausgangspunkt). Im nächsten Artikel schauen wir uns die HTML-Elemente an, die Sie verwenden würden, um die verschiedenen Teile eines HTML-Dokuments zu strukturieren.