text-transform
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Die text-transform
CSS Eigenschaft gibt an, wie der Text eines Elements großgeschrieben werden soll. Sie kann verwendet werden, um Text vollständig in Großbuchstaben oder Kleinbuchstaben darzustellen oder jedes Wort zu kapitalisieren. Sie kann auch helfen, die Lesbarkeit bei Ruby-Text zu verbessern.
Probieren Sie es aus
Die Eigenschaft text-transform
berücksichtigt sprachspezifische Regeln für Groß- und Kleinschreibung wie die folgenden:
- In turkischen Sprachen, wie Türkisch (
tr
), Aserbaidschanisch (az
), Krimtatarisch (crh
), Wolga-Tatarisch (tt
) und Baschkirisch (ba
), gibt es zwei Arten voni
, mit und ohne Punkt, und zwei Paarungen:i
/İ
undı
/I
. - Im Deutschen (
de
) wirdß
zuSS
in Großbuchstaben. - Im Niederländischen (
nl
) wird dasij
Digraph zuIJ
, sogar mittext-transform: capitalize
, das nur den ersten Buchstaben eines Wortes in Großbuchstaben setzt. - Im Griechischen (
el
) verlieren Vokale ihren Akzent, wenn das ganze Wort in Großbuchstaben ist (ά
/Α
), außer bei eta-zurückhaltendem (ή
/Ή
). Zudem verlieren Diphtonge mit einem Akzent auf dem ersten Vokal den Akzent und erhalten ein Diaeresis auf dem zweiten Vokal (άι
/ΑΪ
). - Im Griechischen (
el
) hat das Kleinbuchstaben-Sigma zwei Formen:σ
undς
.ς
wird nur verwendet, wenn Sigma ein Wort beendet. Bei der Anwendung vontext-transform: lowercase
auf ein Großbuchstaben-Sigma (Σ
) muss der Browser die richtige Kleinbuchstabenform basierend auf dem Kontext wählen. - Im Irischen (
ga
) bleiben bestimmte vorangestellte Buchstaben klein, wenn der Basiseingang in Großbuchstaben ist. Zum Beispiel wirdtext-transform: uppercase
ar aon tslí
inAR AON tSLÍ
ändern und nicht, wie man erwarten könnte, inAR AON TSLÍ
(nur Firefox). In einigen Fällen wird beim Uppercasing auch ein Bindestrich entfernt:an t-uisce
transformiert sich inAN tUISCE
(und der Bindestrich wird korrekt durchtext-transform: lowercase
wieder eingesetzt).
Die Sprache wird durch das lang
HTML-Attribut oder das xml:lang
XML-Attribut definiert.
Hinweis: Die Unterstützung für sprachspezifische Fälle variiert zwischen Browsern, daher überprüfen Sie die Browser-Kompatibilitätstabelle.
Syntax
/* Keyword values */
text-transform: none;
text-transform: capitalize;
text-transform: uppercase;
text-transform: lowercase;
text-transform: full-width;
text-transform: full-size-kana;
text-transform: math-auto;
/* Global values */
text-transform: inherit;
text-transform: initial;
text-transform: revert;
text-transform: revert-layer;
text-transform: unset;
capitalize
-
Ist ein Schlüsselwort, das den ersten Buchstaben jedes Wortes in Großbuchstaben umwandelt. Andere Zeichen bleiben unverändert (sie behalten ihre ursprüngliche Groß- oder Kleinschreibung, wie im Text des Elements geschrieben). Ein Buchstabe ist definiert als ein Zeichen, das Teil von Unicodes Hauptkategorien Letter oder Number ist; daher werden alle Satzzeichen oder Symbole am Anfang eines Wortes ignoriert.
Hinweis: Autoren sollten nicht erwarten, dass
capitalize
sprachspezifische Title-Casing-Konventionen (wie das Überspringen von Artikeln im Englischen) befolgt.Hinweis: Das
capitalize
Schlüsselwort war in CSS 1 und CSS 2.1 unzureichend spezifiziert. Dies führte zu Unterschieden zwischen Browsern bei der Berechnung des ersten Buchstabens (Firefox betrachtete-
und_
als Buchstaben, aber andere Browser nicht. Sowohl WebKit als auch Gecko betrachteten Buchstabenbasierte Symbole wieⓐ
fälschlicherweise als echte Buchstaben.) Durch die genaue Definition des richtigen Verhaltens bereinigt CSS Text Level 3 dieses Durcheinander. Diecapitalize
-Zeile in der Browser-Kompatibilitätstabelle enthält die Version, ab der die verschiedenen Engines dieses nun genau definierte Verhalten unterstützt haben. uppercase
-
Ist ein Schlüsselwort, das alle Zeichen in Großbuchstaben umwandelt.
lowercase
-
Ist ein Schlüsselwort, das alle Zeichen in Kleinbuchstaben umwandelt.
none
-
Ist ein Schlüsselwort, das verhindert, dass das Gehäuse aller Zeichen geändert wird.
full-width
-
Ist ein Schlüsselwort, das das Schreiben eines Zeichens - hauptsächlich Ideogramme und lateinische Skripte - in ein Quadrat erzwingt, sodass es in den üblichen ostasiatischen Skripten (wie Chinesisch oder Japanisch) ausgerichtet werden kann.
full-size-kana
-
Wird im Allgemeinen für
<ruby>
-Anmerkungstext verwendet. Das Schlüsselwort konvertiert alle kleinen Kana-Zeichen in das gleichwertige Vollformat-Kana, um Lesbarkeitsprobleme bei den typischerweise bei Ruby verwendeten kleinen Schriftgrößen zu kompensieren. math-auto
-
Wird verwendet, um Text automatisch dort in mathematischen Kursivbuchstaben zu rendern, wo es angebracht ist. Es verwandelt lateinische und griechische Buchstaben sowie einige andere mathematisch relevante Symbole in kursiv mathematische Symbole, jedoch nur, wenn es auf einem Textknoten mit einem einzigen Zeichen angewendet wird. Zum Beispiel wird "x" zu "𝑥" (U+1D465), aber "exp" bleibt als "exp". Es wird hauptsächlich verwendet, um das Verhalten von
<mi>
-Elementen in MathML zu spezifizieren. Sie sollten im Allgemeinen MathML-Markup verwenden, das automatisch die richtige Formatierung anwendet.
Barrierefreiheit
Große Textabschnitte, die mit einem text-transform
Wert von uppercase
gesetzt sind, können für Menschen mit kognitiven Problemen wie Dyslexie schwer lesbar sein.
Formale Definition
Initialer Wert | none |
---|---|
Anwendbar auf | alle Elemente. Auch anwendbar auf ::first-letter und ::first-line . |
Vererbt | Ja |
Berechneter Wert | wie angegeben |
Animationstyp | diskret |
Formale Syntax
Beispiele
Beispiel mit "none"
<p>
Initial String
<strong>Lorem ipsum dolor sit amet, consectetur adipisicing elit…</strong>
</p>
<p>
text-transform: none
<strong
><span
>Lorem ipsum dolor sit amet, consectetur adipisicing elit…</span
></strong
>
</p>
span {
text-transform: none;
}
strong {
float: right;
}
Dies demonstriert keine Texttransformation.
Beispiel mit "capitalize" (allgemein)
<p>
Initial String
<strong>Lorem ipsum dolor sit amet, consectetur adipisicing elit…</strong>
</p>
<p>
text-transform: capitalize
<strong
><span
>Lorem ipsum dolor sit amet, consectetur adipisicing elit…</span
></strong
>
</p>
span {
text-transform: capitalize;
}
strong {
float: right;
}
Dies demonstriert die Großschreibung von Text.
Beispiel mit "capitalize" (Zeichensetzung)
<p>
Initial String
<strong
>(this) "is" [a] –short– -test- «for» *the* _css_ ¿capitalize?
?¡transform!</strong
>
</p>
<p>
text-transform: capitalize
<strong
><span
>(this) "is" [a] –short– -test- «for» *the* _css_ ¿capitalize?
?¡transform!</span
></strong
>
</p>
span {
text-transform: capitalize;
}
strong {
float: right;
}
Dies demonstriert, wie anfängliche Satzzeichen eines Wortes ignoriert werden. Das Schlüsselwort zielt auf den ersten Buchstaben, das ist das erste Unicode-Zeichen, das Teil der Hauptkategorie Letter oder Number ist.
Beispiel mit "capitalize" (Symbole)
<p>
Initial String
<strong>ⓐⓑⓒ (ⓓⓔⓕ) —ⓖⓗⓘ— ⓙkl</strong>
</p>
<p>
text-transform: capitalize
<strong><span>ⓐⓑⓒ (ⓓⓔⓕ) —ⓖⓗⓘ— ⓙkl</span></strong>
</p>
span {
text-transform: capitalize;
}
strong {
float: right;
}
Dies demonstriert, wie anfängliche Symbole ignoriert werden. Das Schlüsselwort zielt auf den ersten Buchstaben, das ist das erste Unicode-Zeichen, das Teil der Hauptkategorie Letter oder Number ist.
Beispiel mit "capitalize" (Niederländisches ij-Digraph)
<p>
Initial String
<strong lang="nl">The Dutch word: "ijsland" starts with a digraph.</strong>
</p>
<p>
text-transform: capitalize
<strong
><span lang="nl"
>The Dutch word: "ijsland" starts with a digraph.</span
></strong
>
</p>
span {
text-transform: capitalize;
}
strong {
float: right;
}
Dies demonstriert, wie das niederländische ij Digraph wie ein einzelner Buchstabe behandelt werden muss.
Beispiel mit "uppercase" (allgemein)
<p>
Initial String
<strong>Lorem ipsum dolor sit amet, consectetur adipisicing elit…</strong>
</p>
<p>
text-transform: uppercase
<strong
><span
>Lorem ipsum dolor sit amet, consectetur adipisicing elit…</span
></strong
>
</p>
span {
text-transform: uppercase;
}
strong {
float: right;
}
Dies demonstriert das Umwandeln des Textes in Großbuchstaben.
Beispiel mit "uppercase" (Griechische Vokale)
<p>
Initial String
<strong>Θα πάμε στο "Θεϊκό φαΐ" ή στη "Νεράιδα"</strong>
</p>
<p>
text-transform: uppercase
<strong
><span lang="el">Θα πάμε στο "Θεϊκό φαΐ" ή στη "Νεράιδα"</span></strong
>
</p>
span {
text-transform: uppercase;
}
strong {
float: right;
}
Dies demonstriert, wie griechische Vokale, außer disjunktivem eta, keinen Akzent haben sollten, und der Akzent auf dem ersten Vokal eines Vokalpaars zu einem Diaeresis auf dem zweiten Vokal wird.
Beispiel mit "lowercase" (allgemein)
<p>
Initial String
<strong>Lorem ipsum dolor sit amet, consectetur adipisicing elit…</strong>
</p>
<p>
text-transform: lowercase
<strong
><span
>Lorem ipsum dolor sit amet, consectetur adipisicing elit…</span
></strong
>
</p>
span {
text-transform: lowercase;
}
strong {
float: right;
}
Dies demonstriert das Umwandeln des Textes in Kleinbuchstaben.
Beispiel mit "lowercase" (Griechisches Σ)
<p>
Initial String
<strong>Σ IS A greek LETTER that appears SEVERAL TIMES IN ΟΔΥΣΣΕΥΣ.</strong>
</p>
<p>
text-transform: lowercase
<strong
><span
>Σ IS A greek LETTER that appears SEVERAL TIMES IN ΟΔΥΣΣΕΥΣ.</span
></strong
>
</p>
span {
text-transform: lowercase;
}
strong {
float: right;
}
Dies demonstriert, wie das griechische Zeichen Sigma (Σ
) in das reguläre Kleinbuchstaben-Sigma (σ
) oder die wortabschließende Variante (ς
) umgewandelt wird, abhängig vom Kontext.
Beispiel mit "lowercase" (Litauisch)
<p>
Initial String
<strong>Ĩ is a Lithuanian LETTER as is J́</strong>
</p>
<p>
text-transform: lowercase
<strong><span lang="lt">Ĩ is a Lithuanian LETTER as is J́</span></strong>
</p>
span {
text-transform: lowercase;
}
strong {
float: right;
}
Dies demonstriert, wie die litauischen Buchstaben Ĩ
und J́
ihren Punkt behalten, wenn sie in Kleinbuchstaben umgewandelt werden.
Beispiel mit "full-width" (allgemein)
<p>
Initial String
<strong
>0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!"#$%&()*+,-./:;<=>?@{|}~</strong
>
</p>
<p>
text-transform: full-width
<strong
><span
>0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!"#$%&()*+,-./:;<=>?@{|}~</span
></strong
>
</p>
span {
text-transform: full-width;
}
strong {
width: 100%;
float: right;
}
Einige Zeichen existieren in zwei Formaten: normale Breite und volle Breite, mit unterschiedlichen Unicode-Codepunkten. Die volle Breite wird verwendet, um sie nahtlos mit asiatischen ideografischen Zeichen zu mischen.
Beispiel mit "full-width" (Japanische Halbbreit-Katakana)
<p>
Initial String
<strong>ウェブプログラミングの勉強</strong>
</p>
<p>
text-transform: full-width
<strong><span>ウェブプログラミングの勉強</span></strong>
</p>
span {
text-transform: full-width;
}
strong {
width: 100%;
float: right;
}
Die japanischen Halbbreit-Katakana wurden verwendet, um Katakana in 8-Bit-Zeichencodes darzustellen. Im Gegensatz zu regulären (vollbreiten) Katakana-Zeichen wird ein Buchstabe mit Dakuten (Stimmzeichen) als zwei Codepunkte dargestellt, dem Körper des Buchstabens und dem Dakuten. full-width
kombiniert diese zu einem einzigen Codepunkt, wenn es diese Zeichen in volle Breite umwandelt.
Beispiel mit "full-size-kana"
<p>ァィゥェ ォヵㇰヶ ㇱㇲッㇳ ㇴㇵㇶㇷ ㇸㇹㇺャ ュョㇻㇼ ㇽㇾㇿヮ</p>
<p>ァィゥェ ォヵㇰヶ ㇱㇲッㇳ ㇴㇵㇶㇷ ㇸㇹㇺャ ュョㇻㇼ ㇽㇾㇿヮ</p>
p:nth-of-type(2) {
text-transform: full-size-kana;
}
Beispiel mit "math-auto"
In diesem Beispiel verwenden wir reines HTML-Markup, um eine mathematische Formel zu erstellen:
<div>
(<span class="math-id">sin</span> <span class="math-id">x</span>)<sup
>2</sup
>
+ (<span class="math-id">cos</span> <span class="math-id">x</span>)<sup
>2</sup
>
= 1
</div>
Wir geben jedem .math-id
Element text-transform: math-auto
. Beachten Sie jedoch, wie nur die x
-Zeichen kursiv werden, während sin
und cos
unverändert bleiben.
.math-id {
text-transform: math-auto;
}
Es wird jedoch empfohlen, MathML für mathematische Formeln zu verwenden, da es eine robustere und zugänglichere Möglichkeit bietet, mathematische Inhalte darzustellen. Hier ist die gleiche Formel mit MathML:
<math xmlns="http://www.w3.org/1998/Math/MathML" display="block">
<semantics>
<mrow>
<mo stretchy="false">(</mo>
<mo lspace="0em" rspace="0em">sin</mo>
<mspace width="0.16666666666666666em"></mspace>
<mi>x</mi>
<msup>
<mo stretchy="false">)</mo>
<mn>2</mn>
</msup>
<mo>+</mo>
<mo stretchy="false">(</mo>
<mo lspace="0em" rspace="0em">cos</mo>
<mspace width="0.16666666666666666em"></mspace>
<mi>x</mi>
<msup>
<mo stretchy="false">)</mo>
<mn>2</mn>
</msup>
<mo>=</mo>
<mn>1</mn>
</mrow>
<annotation encoding="TeX">(\sin\,x)^2+(\cos\,x)^2=1</annotation>
</semantics>
</math>
Spezifikationen
Specification |
---|
CSS Text Module Level 4 # text-transform |
Browser-Kompatibilität
BCD tables only load in the browser