diff options
author | Peter Bengtsson <mail@peterbe.com> | 2020-12-14 12:18:12 -0500 |
---|---|---|
committer | Peter Bengtsson <mail@peterbe.com> | 2020-12-14 12:18:12 -0500 |
commit | 869dd2069c695ee7040cd3261713212155819f42 (patch) | |
tree | 320a95de75a89686a9df006b90d923aa7fa0d551 /files/de/web/css | |
parent | a5fcfafb665e96cae5d04dfba927db8dcdfd7f14 (diff) | |
download | translated-content-869dd2069c695ee7040cd3261713212155819f42.tar.gz translated-content-869dd2069c695ee7040cd3261713212155819f42.tar.bz2 translated-content-869dd2069c695ee7040cd3261713212155819f42.zip |
final dump 2020-12-14
Diffstat (limited to 'files/de/web/css')
11 files changed, 1210 insertions, 332 deletions
diff --git a/files/de/web/css/containing_block/index.html b/files/de/web/css/containing_block/index.html new file mode 100644 index 0000000000..94577e99cc --- /dev/null +++ b/files/de/web/css/containing_block/index.html @@ -0,0 +1,258 @@ +--- +title: Layout und der enthaltende Block +slug: Web/CSS/Containing_block +translation_of: Web/CSS/Containing_block +--- +<div>{{cssref}}</div> + +<p>The size and position of an element are often impacted by its <strong>containing block</strong>. Most often, the containing block is the <a href="/en-US/docs/Web/CSS/CSS_Box_Model/Introduction_to_the_CSS_box_model#content-area">content area</a> of an element's nearest <a href="/en-US/docs/Web/HTML/Block-level_elements">block-level</a> ancestor, but this is not always the case. <span class="seoSummary">In this article, we examine the factors that determine an element's containing block.</span></p> + +<p>When a user agent (such as your browser) lays out a document, it generates a box for every element. Each box is divided into four areas:</p> + +<ol start="1"> + <li>Content area</li> + <li>Padding area</li> + <li>Border area</li> + <li>Margin area</li> +</ol> + +<p><img alt="Diagram of the box model" src="https://mdn.mozillademos.org/files/16558/box-model.png" style="height: 300px; width: 544px;"></p> + +<p>Many developers believe that the containing block of an element is always the content area of its parent, but that isn't necessarily true. Let's investigate the factors that determine what an element's containing block is.</p> + +<h2 id="Effects_of_the_containing_block">Effects of the containing block</h2> + +<p>Before learning what determines the containing block of an element, it's useful to know why it matters in the first place.</p> + +<p>The size and position of an element are often impacted by its containing block. Percentage values that are applied to the {{cssxref("width")}}, {{cssxref("height")}}, {{cssxref("padding")}}, {{cssxref("margin")}}, and offset properties of an absolutely positioned element (i.e., which has its {{cssxref("position")}} set to <code>absolute</code> or <code>fixed</code>) are computed from the element's containing block.</p> + +<h2 id="Identifying_the_containing_block">Identifying the containing block</h2> + +<p>The process for identifying the containing block depends entirely on the value of the element's {{cssxref("position")}} property:</p> + +<ol start="1"> + <li>If the <code>position</code> property is <code><strong>static</strong></code>, <code><strong>relative</strong></code>, or <strong><code>sticky</code></strong>, the containing block is formed by the edge of the <em>content box</em> of the nearest ancestor element that is either <strong>a block container</strong> (such as an inline-block, block, or list-item element) or <strong>establishes a formatting context</strong> (such as a table container, flex container, grid container, or the block container itself).</li> + <li>If the <code>position</code> property is <code><strong>absolute</strong></code>, the containing block is formed by the edge of the <em>padding box</em> of the nearest ancestor element that has a <code>position</code> value other than <code>static</code> (<code>fixed</code>, <code>absolute</code>, <code>relative</code>, or <code>sticky</code>).</li> + <li>If the <code>position</code> property is <code><strong>fixed</strong></code>, the containing block is established by the {{glossary("viewport")}} (in the case of continuous media) or the page area (in the case of paged media).</li> + <li>If the <code>position</code> property is <code><strong>absolute</strong></code> or <code><strong>fixed</strong></code>, the containing block may also be formed by the edge of the <em>padding box</em> of the nearest ancestor element that has the following: + <ol start="1"> + <li>A {{cssxref("transform")}} or {{cssxref("perspective")}} value other than <code>none</code></li> + <li>A {{cssxref("will-change")}} value of <code>transform</code> or <code>perspective</code></li> + <li>A {{cssxref("filter")}} value other than <code>none</code> or a <code>will-change</code> value of <code>filter</code> (only works on Firefox).</li> + <li>A {{cssxref("contain")}} value of <code>paint</code> (e.g. <code>contain: paint;</code>)</li> + </ol> + </li> +</ol> + +<div class="note"> +<p><strong>Note:</strong> The containing block in which the root element ({{HTMLElement("html")}}) resides is a rectangle called the <strong>initial containing block</strong>. It has the dimensions of the viewport (for continuous media) or the page area (for paged media).</p> +</div> + +<h2 id="Calculating_percentage_values_from_the_containing_block">Calculating percentage values from the containing block</h2> + +<p>As noted above, when certain properties are given a percentage value, the computed value depends on the element's containing block. The properties that work this way are <strong>box model properties</strong> and <strong>offset properties</strong>:</p> + +<ol start="1"> + <li>The {{cssxref("height")}}, {{cssxref("top")}}, and {{cssxref("bottom")}} properties compute percentage values from the <code>height</code> of the containing block.</li> + <li>The {{cssxref("width")}}, {{cssxref("left")}}, {{cssxref("right")}}, {{cssxref("padding")}}, and {{cssxref("margin")}} properties compute percentage values from the <code>width</code> of the containing block.</li> +</ol> + +<h2 id="Some_examples">Some examples</h2> + +<p>The HTML code for all our examples is:</p> + +<pre class="brush: html notranslate"><body> + <section> + <p>This is a paragraph!</p> + </section> +</body> +</pre> + +<p>Only the CSS is altered in each instance below.</p> + +<h3 id="Example_1">Example 1</h3> + +<p>In this example, the paragraph is statically positioned, so its containing block is {{HTMLElement("section")}} because it's the nearest ancestor that is a block container.</p> + +<div class="hidden"> +<pre class="brush: html notranslate"><body> + <section> + <p>This is a paragraph!</p> + </section> +</body> +</pre> +</div> + +<pre class="brush: css notranslate">body { + background: beige; +} + +section { + display: block; + width: 400px; + height: 160px; + background: lightgray; +} + +p { + width: 50%; /* == 400px * .5 = 200px */ + height: 25%; /* == 160px * .25 = 40px */ + margin: 5%; /* == 400px * .05 = 20px */ + padding: 5%; /* == 400px * .05 = 20px */ + background: cyan; +} +</pre> + +<p>{{EmbedLiveSample('Example_1','100%','300')}}</p> + +<h3 id="Example_2">Example 2</h3> + +<p>In this example, the paragraph's containing block is the {{HTMLElement("body")}} element, because <code><section></code> is not a block container (because of <code>display: inline</code>) and doesn’t establish a formatting context.</p> + +<div class="hidden"> +<pre class="brush: html notranslate"><body> + <section> + <p>This is a paragraph!</p> + </section> +</body> +</pre> +</div> + +<pre class="brush: css notranslate">body { + background: beige; +} + +section { + display: inline; + background: lightgray; +} + +p { + width: 50%; /* == half the body's width */ + height: 200px; /* Note: a percentage would be 0 */ + background: cyan; +} +</pre> + +<p>{{EmbedLiveSample('Example_2','100%','300')}}</p> + +<h3 id="Example_3">Example 3</h3> + +<p>In this example, the paragraph's containing block is <code><section></code> because the latter's <code>position</code> is <code>absolute</code>. The paragraph's percentage values are affected by the <code>padding</code> of its containing block, though if the containing block's {{cssxref("box-sizing")}} value were <code>border-box</code> this would not be the case.</p> + +<div class="hidden"> +<pre class="brush: html notranslate"><body> + <section> + <p>This is a paragraph!</p> + </section> +</body> +</pre> +</div> + +<pre class="brush: css notranslate">body { + background: beige; +} + +section { + position: absolute; + left: 30px; + top: 30px; + width: 400px; + height: 160px; + padding: 30px 20px; + background: lightgray; +} + +p { + position: absolute; + width: 50%; /* == (400px + 20px + 20px) * .5 = 220px */ + height: 25%; /* == (160px + 30px + 30px) * .25 = 55px */ + margin: 5%; /* == (400px + 20px + 20px) * .05 = 22px */ + padding: 5%; /* == (400px + 20px + 20px) * .05 = 22px */ + background: cyan; +} +</pre> + +<p>{{EmbedLiveSample('Example_3','100%','300')}}</p> + +<h3 id="Example_4">Example 4</h3> + +<p>In this example, the paragraph's <code>position</code> is <code>fixed</code>, so its containing block is the initial containing block (on screens, the viewport). Thus, the paragraph's dimensions change based on the size of the browser window.</p> + +<div class="hidden"> +<pre class="brush: html notranslate"><body> + <section> + <p>This is a paragraph!</p> + </section> +</body> +</pre> +</div> + +<pre class="brush: css notranslate">body { + background: beige; +} + +section { + width: 400px; + height: 480px; + margin: 30px; + padding: 15px; + background: lightgray; +} + +p { + position: fixed; + width: 50%; /* == (50vw - (width of vertical scrollbar)) */ + height: 50%; /* == (50vh - (height of horizontal scrollbar)) */ + margin: 5%; /* == (5vw - (width of vertical scrollbar)) */ + padding: 5%; /* == (5vw - (width of vertical scrollbar)) */ + background: cyan; +} +</pre> + +<p>{{EmbedLiveSample('Example_4','100%','300')}}</p> + +<h3 id="Example_5">Example 5</h3> + +<p>In this example, the paragraph's <code>position</code> is <code>absolute</code>, so its containing block is <code><section></code>, which is the nearest ancestor with a {{cssxref("transform")}} property that isn't <code>none</code>.</p> + +<div class="hidden"> +<pre class="brush: html notranslate"><body> + <section> + <p>This is a paragraph!</p> + </section> +</body> +</pre> +</div> + +<pre class="brush: css notranslate">body { + background: beige; +} + +section { + transform: rotate(0deg); + width: 400px; + height: 160px; + background: lightgray; +} + +p { + position: absolute; + left: 80px; + top: 30px; + width: 50%; /* == 200px */ + height: 25%; /* == 40px */ + margin: 5%; /* == 20px */ + padding: 5%; /* == 20px */ + background: cyan; +} +</pre> + +<p>{{EmbedLiveSample('Example_5','100%','300')}}</p> + +<h2 id="See_also">See also</h2> + +<ul> + <li>{{css_key_concepts}}</li> + <li>The {{cssxref("all")}} property resets all CSS declarations to a given known state</li> +</ul> diff --git a/files/de/web/css/css_transforms/css_transformationen_verwenden/index.html b/files/de/web/css/css_transforms/css_transformationen_verwenden/index.html index 83a9ada0d2..0d761f544f 100644 --- a/files/de/web/css/css_transforms/css_transformationen_verwenden/index.html +++ b/files/de/web/css/css_transforms/css_transformationen_verwenden/index.html @@ -15,41 +15,47 @@ translation_of: Web/CSS/CSS_Transforms/Using_CSS_transforms <p>CSS Transformationen sind als eine Reihe von CSS Eigenschaften implementiert, die es erlauben, affine lineare Transformationen auf HTML Elemente anzuwenden. Diese Transformationen beinhalten Drehung, Verzerrung, Skalierung und Verschiebung sowohl im ebenen als auch im 3D Raum.</p> +<div class="warning"> +<p>Nur Elemente, die durch das Box-Modell positioniert werden, können transformiert werden. Als Faustregel gilt, dass ein Element durch das Box-Modell positioniert wird, wenn es <code>display: block</code> hat.</p> +</div> + <h2 id="CSS_Transformationseigenschaften">CSS Transformationseigenschaften</h2> <p>Zwei Haupteigenschaften werden dazu verwendet, CSS Transformationen zu definieren: {{cssxref("transform")}} und {{cssxref("transform-origin")}}.</p> <dl> - <dt>{{cssxref("transform-origin")}}</dt> - <dd>Bestimmt die Position des Ursprungs. Standardmäßig ist dieser in der Mitte des Elements und kann verschoben werden. Er wird von mehreren Transformationen verwendet wie Drehung, Skalierung oder Verzerrung, die einen bestimmten Punkt als Parameter benötigen.</dd> <dt>{{cssxref("transform")}}</dt> <dd>Bestimmt die Transformationen, die auf das Element angewendet werden. Sie ist eine leerzeichenseparierte Liste von Transformationen, welche eine nach der anderen angewendet werden, wie durch die Zusammensetzungsoperation verlangt.</dd> + <dt>{{cssxref("transform-origin")}}</dt> + <dd>Bestimmt die Position des Ursprungs. Standardmäßig ist dieser in der Mitte des Elements und kann verschoben werden. Er wird von mehreren Transformationen verwendet wie Drehung, Skalierung oder Verzerrung, die einen bestimmten Punkt als Parameter benötigen.</dd> </dl> <h2 id="Beispiele">Beispiele</h2> -<h3 id="Drehung">Drehung</h3> +<p>Hier ist ein unverändertes Bild des MDN-Logos:</p> -<p>Dieses Beispiel erstellt einen iframe, der Googles Homepage beinhaltet, die um 90 Grad um die linke untere Ecke gedreht wurde.</p> +<p><img alt="MDN Logo" src="https://mdn.mozillademos.org/files/12539/Screen%20Shot%202016-02-16%20at%2015.53.54.png" style="height: 106px; width: 110px;"></p> -<p><a class="button liveSample" href="/@api/deki/files/2921/=rotated-google-sample.html" title="/@api/deki/files/2921/=rotated-google-sample.html">Livebeispiel ansehen</a> <a class="button liveSample" href="/@api/deki/files/2920/=google-rotated.png" title="/@api/deki/files/2920/=google-rotated.png">Screenshot des Beispiels ansehen</a></p> +<h3 id="Rotating" name="Rotating">Drehung</h3> -<pre class="brush: html"><div style="transform: rotate(90deg); transform-origin: bottom left;"> - <iframe src="http://www.google.com/" width="500" height="600"></iframe> -</div> +<p>Dieses Beispiel erstellt einen iframe, der Googles Homepage beinhaltet, die um 90 Grad um die linke untere Ecke gedreht wurde.</p> + +<pre class="brush: html notranslate"><img style="transform: rotate(90deg); + transform-origin: bottom left;" + src="https://mdn.mozillademos.org/files/12539/Screen%20Shot%202016-02-16%20at%2015.53.54.png"> </pre> -<h3 id="Verzerrung_und_Verschiebung">Verzerrung und Verschiebung</h3> +<p>{{EmbedLiveSample('Rotating', 'auto', 240) }}</p> + +<h3 id="Skewing_and_translating" name="Skewing_and_translating">Verzerrung und Verschiebung</h3> <p>Dieses Beispiel erstellt einen iframe, der Googles Homepage beinhaltet, verzerrt um 10 Grad und verschoben um 150 Pixel auf der x-Achse.</p> -<p><a class="button liveSample" href="/@api/deki/files/2922/=skewed-google-sample.html" title="http://developer.mozilla.org/editor/fckeditor/core/editor/@api/deki/files/2922/=skewed-google-sample.html">Livebeispiel ansehen</a> <a class="button liveSample" href="/@api/deki/files/2923/=skewed-google.png" title="/@api/deki/files/2923/=skewed-google.png">Screenshot des Beispiels ansehen</a></p> +<pre class="brush: html notranslate"><img style="transform: skewx(10deg) translatex(150px); + transform-origin: bottom left;" + src="https://mdn.mozillademos.org/files/12539/Screen%20Shot%202016-02-16%20at%2015.53.54.png"></pre> -<pre class="brush: html"><div style="transform: skewx(10deg) translatex(150px); - transform-origin: bottom left;"> - <iframe src="http://www.google.com/" width="600" height="500"></iframe> -</div> -</pre> +<p>{{EmbedLiveSample('Skewing_and_translating') }}</p> <h2 id="3D-spezifische_CSS_Eigenschaften">3D-spezifische CSS Eigenschaften</h2> @@ -57,192 +63,20 @@ translation_of: Web/CSS/CSS_Transforms/Using_CSS_transforms <h3 id="Eine_Perspektive_einrichten">Eine Perspektive einrichten</h3> -<p>Das erste Element ist das Setzen der <em>Perspektive</em>. Die Perspektive ist, was den dreidimensionalen Eindruck vermittelt. Je weiter weg Elemente vom Betrachter sind, desto kleiner sind sie.</p> - -<p>Wie schnell sie kleiner werden, wird durch die {{cssxref("perspective")}} Eigenschaft bestimmt. Je kleiner deren Wert ist, desto tiefer ist die Perspektive.</p> - -<table class="standard-table"> - <thead> - <tr> - <th><code>perspective:0;</code></th> - <th><code>perspective:250px;</code></th> - </tr> - </thead> - <tbody> - <tr> - <td> - <div class="container" style="width: 200px; height: 200px; margin: 75px 0 0 75px; border: none;"> - <div class="cube" style="width: 100%; height: 100%; -moz-perspective: 0; -webkit-perspective: 0; perspective: 0; -moz-transform-style: preserve-3d; -webkit-transform-style: preserve-3d; transform-style: preserve-3d; -moz-perspective-origin: 150% 150%; -webkit-perspective-origin: 150% 150%; perspective-origin: 150% 150%;"> - <div class="middle" style="display: block; position: absolute; width: 100px; height: 100px; border: 1px dashed black; line-height: 100px; font-family: arial, sans-serif; font-size: 60px; color: white; text-align: center; background: transparent;"> </div> - - <div class="front">1</div> - - <div class="back">2</div> - - <div class="right">3</div> - - <div class="left">4</div> - - <div class="top">5</div> - - <div class="bottom">6</div> - </div> - </div> - </td> - <td> - <div class="container" style="width: 200px; height: 200px; margin: 75px 0 0 75px; border: none;"> - <div class="cube" style="width: 100%; height: 100%; -moz-perspective: 250px; -webkit-perspective: 250px; perspective: 250px; -moz-transform-style: preserve-3d; -webkit-transform-style: preserve-3d; transform-style: preserve-3d; -moz-perspective-origin: 150% 150%; -webkit-perspective-origin: 150% 150%; perspective-origin: 150% 150%;"> - <div class="middle" style="display: block; position: absolute; width: 100px; height: 100px; border: 1px dashed black; line-height: 100px; font-family: arial, sans-serif; font-size: 60px; color: white; text-align: center; background: transparent;"> </div> - - <div class="front">1</div> - - <div class="back">2</div> - - <div class="right">3</div> - - <div class="left">4</div> - - <div class="top">5</div> - - <div class="bottom">6</div> - </div> - </div> - </td> - </tr> - </tbody> -</table> - -<table class="standard-table"> - <thead> - <tr> - <th><code>perspective:300px;</code></th> - <th><code>perspective:350px;</code></th> - </tr> - </thead> - <tbody> - <tr> - <td> - <div class="container" style="width: 200px; height: 200px; margin: 75px 0 0 75px; border: none;"> - <div class="cube" style="width: 100%; height: 100%; -moz-perspective: 300px; -moz-transform-style: preserve-3d; -moz-perspective-origin: 150% 150%; -webkit-perspective: 300px; -webkit-transform-style: preserve-3d; -webkit-perspective-origin: 150% 150%; perspective: 300px; transform-style: preserve-3d; perspective-origin: 150% 150%;"> - <div class="middle" style="display: block; position: absolute; width: 100px; height: 100px; border: 1px dashed black; line-height: 100px; font-family: arial, sans-serif; font-size: 60px; color: white; text-align: center; background: transparent;"> </div> - - <div class="front">1</div> - - <div class="back">2</div> +<p>Das erste zu setzende Element ist die {{cssxref("perspective")}}. Die Perspektive ist das, was uns den 3D-Eindruck vermittelt. Je weiter die Elemente vom Betrachter entfernt sind, desto kleiner sind sie.</p> - <div class="right">3</div> +<p>{{page("/en-US/docs/Web/CSS/perspective", "Setting perspective", 0, 0, 3)}}</p> - <div class="left">4</div> +<p>Das zweite Element, das konfiguriert werden muss, ist die Position des Betrachters mit der Eigenschaft {{ cssxref("perspective-origin") }}. Standardmäßig ist die Perspektive auf den Betrachter zentriert, was nicht immer ausreichend ist.</p> - <div class="top">5</div> - - <div class="bottom">6</div> - </div> - </div> - </td> - <td> - <div class="container" style="width: 200px; height: 200px; margin: 75px 0 0 75px; border: none;"> - <div class="cube" style="width: 100%; height: 100%; -moz-perspective: 350px; -moz-transform-style: preserve-3d; -moz-perspective-origin: 150% 150%; -webkit-perspective: 350px; -webkit-transform-style: preserve-3d; -webkit-perspective-origin: 150% 150%; perspective: 350px; transform-style: preserve-3d; perspective-origin: 150% 150%;"> - <div class="middle" style="display: block; position: absolute; width: 100px; height: 100px; border: 1px dashed black; line-height: 100px; font-family: arial, sans-serif; font-size: 60px; color: white; text-align: center; background: transparent;"> </div> - - <div class="front">1</div> - - <div class="back">2</div> - - <div class="right">3</div> - - <div class="left">4</div> - - <div class="top">5</div> - - <div class="bottom">6</div> - </div> - </div> - </td> - </tr> - </tbody> -</table> - -<p>Das zweite Element ist die Konfiguration der Position des Betrachters mittels der {{cssxref("perspective-origin")}} Eigenschaft. Standardmäßig ist die Perspektive auf den Betrachter zentriert, was nicht immer passend ist.</p> - -<div> -<table class="standard-table"> - <thead> - <tr> - <th><code>perspective-origin:150px 150px;</code></th> - <th><code>perspective-origin:50% 50%;</code></th> - <th><code>perspective-origin:-50px -50px;</code></th> - </tr> - </thead> - <tbody> - <tr> - <td> - <div class="container" style="width: 100px; height: 100px; margin: 25px; border: none;"> - <div class="cube" style="width: 100%; height: 100%; -moz-perspective: 300px; -moz-transform-style: preserve-3d; -moz-perspective-origin: 150% 150%; -webkit-perspective: 300px; -webkit-transform-style: preserve-3d; -webkit-perspective-origin: 150% 150%; perspective: 300px; transform-style: preserve-3d; perspective-origin: 150% 150%;"> - <div class="middle" style="display: block; position: absolute; width: 100px; height: 100px; border: 1px dashed black; line-height: 100px; font-family: arial, sans-serif; font-size: 60px; color: white; text-align: center; background: transparent;"> </div> - - <div class="front">1</div> - - <div class="back">2</div> - - <div class="right">3</div> - - <div class="left">4</div> - - <div class="top">5</div> - - <div class="bottom">6</div> - </div> - </div> - </td> - <td> - <div class="container" style="width: 100px; height: 100px; margin: 25px; border: none;"> - <div class="cube" style="width: 100%; height: 100%; -moz-perspective: 300px; -moz-transform-style: preserve-3d; -moz-perspective-origin: 50% 50%; -webkit-perspective: 300px; -webkit-transform-style: preserve-3d; -webkit-perspective-origin: 50% 50%; perspective: 300px; transform-style: preserve-3d; perspective-origin: 50% 50%;"> - <div class="middle" style="display: block; position: absolute; width: 100px; height: 100px; border: 1px dashed black; line-height: 100px; font-family: arial, sans-serif; font-size: 60px; color: white; text-align: center; background: transparent;"> </div> - - <div class="front">1</div> - - <div class="back">2</div> - - <div class="right">3</div> - - <div class="left">4</div> - - <div class="top">5</div> - - <div class="bottom">6</div> - </div> - </div> - </td> - <td> - <div class="container" style="width: 100px; height: 100px; margin: 25px; border: none;"> - <div class="cube" style="width: 100%; height: 100%; -moz-perspective: 300px; -moz-transform-style: preserve-3d; -moz-perspective-origin: -50% -50%; -webkit-perspective: 300px; -webkit-transform-style: preserve-3d; -webkit-perspective-origin: -50% -50%; perspective: 300px; transform-style: preserve-3d; perspective-origin: -50% -50%;"> - <div class="middle" style="display: block; position: absolute; width: 100px; height: 100px; border: 1px dashed black; line-height: 100px; font-family: arial, sans-serif; font-size: 60px; color: white; text-align: center; background: transparent;"> </div> - - <div class="front">1</div> - - <div class="back">2</div> - - <div class="right">3</div> - - <div class="left">4</div> - - <div class="top">5</div> - - <div class="bottom">6</div> - </div> - </div> - </td> - </tr> - </tbody> -</table> -</div> +<p>{{page("/en-US/docs/Web/CSS/perspective-origin", "Changing the perspective origin", 0, 0, 3)}}</p> -<p>Sobald dies getan ist, kann mit der Arbeit am Element im dreidimensionalen Raum begonnen werden.</p> +<p>Sobald Sie dies getan haben, können Sie das Element im 3D-Raum bearbeiten.</p> <h2 id="Siehe_auch">Siehe auch</h2> <ul> <li><a href="/de/docs/Web/Guide/Events/Gerätausrichtung_mit_3D_Transformationen_verwenden">Gerätausrichtung mit 3D Transformationen verwenden</a></li> <li><a href="http://desandro.github.com/3dtransforms/">Einführung in CSS 3D Transformationen</a> (Blogeintrag von David DeSandro in Englisch)</li> + <li><a href="https://css-transform.moro.es/">CSS Transform Playground</a> (Online-Tool zur Visualisierung von CSS Transformationsfunktionen)</li> </ul> diff --git a/files/de/web/css/media_queries/index.html b/files/de/web/css/media_queries/index.html index c6da1617ab..7010034fea 100644 --- a/files/de/web/css/media_queries/index.html +++ b/files/de/web/css/media_queries/index.html @@ -10,13 +10,36 @@ tags: - TopicStub translation_of: Web/CSS/Media_Queries --- -<p>{{CSSRef}}</p> +<div class="boxed translate-rendered text-content"> +<div> +<div class="boxed translate-rendered text-content"> +<div>{{CSSRef}}</div> -<p><strong>Media Queries</strong> is a module of CSS that defines expressions allowing to tailor presentations to a specific range of output devices without changing the content itself.</p> +<p>Mit <strong>Media Queries</strong> können Sie Ihre Website oder App abhängig vom Vorhandensein oder Wert verschiedener Geräteeigenschaften und Parameter anpassen.</p> -<h2 id="Reference">Reference</h2> +<p>Sie sind eine Schlüsselkomponente des <a href="/de/docs/Web/Progressive_web_apps">responsiven Designs</a>. Eine Media Query kann zum Beispiel die Schriftgröße auf kleinen Geräten verkleinern, den Abstand zwischen Absätzen vergrößern, wenn eine Seite im Hochformat angezeigt wird, oder die Größe von Schaltflächen auf Touchscreens erhöhen.</p> -<h3 id="At-rules">At-rules</h3> +<p>Verwenden Sie in <a href="/de/docs/Web/CSS">CSS</a> die <a href="/de/docs/Web/CSS/At-rule">@-Regeln</a> {{cssxref("@media")}}, um einen Teil eines Stylesheets basierend auf dem Ergebnis einer Media Query bedingt anzuwenden. Verwenden Sie {{cssxref("@import")}}, um ein ganzes Stylesheet bedingt anzuwenden.</p> + +<h3 id="Media_Queries_in_HTML">Media Queries in HTML</h3> + +<p>In <a href="/de/docs/Web/HTML">HTML</a> können Media-Queries auf verschiedene Elemente angewendet werden:</p> + +<ul> + <li>Im {{HTMLElement("link")}}-Attribut des {{htmlattrxref("media", "link")}}-Elements definieren sie das Medium, auf das eine verlinkte Ressource (typischerweise CSS) angewendet werden soll.</li> + <li>Im {{HTMLElement("source")}}-Attribut des {{htmlattrxref("media", "source")}}-Elements definieren sie die Medien, auf die diese Quelle angewendet werden soll. (Dies ist nur innerhalb von {{HTMLElement("Bild")}}-Elementen gültig.)</li> + <li>Im {{HTMLElement("style")}}-Attribut des Elements {{htmlattrxref("media", "style")}} definieren sie die Medien, auf die der Stil angewendet werden soll.</li> +</ul> + +<h3 id="Media_Queries_in_JavaScript">Media Queries in JavaScript</h3> + +<p>In JavaScript können Sie die Methode {{domxref("Window.matchMedia()")}} verwenden, um das Fenster gegen eine Medienabfrage zu testen. Sie können auch {{domxref("MediaQueryList.addListener()")}} verwenden, um benachrichtigt zu werden, wenn sich der Zustand einer Abfrage ändert. Mit dieser Funktionalität kann Ihre Website oder App auf Änderungen der Gerätekonfiguration, der Ausrichtung oder des Zustands reagieren.</p> + +<p>Mehr über die programmatische Verwendung von Media Queries erfahren Sie in <a href="/de/docs/Web/CSS/Media_Queries/Testing_media_queries">Media Queries testen</a>.</p> + +<h2 id="Referenz">Referenz</h2> + +<h3 id="-Regeln">@-Regeln</h3> <div class="index"> <ul> @@ -25,52 +48,61 @@ translation_of: Web/CSS/Media_Queries </ul> </div> -<h2 id="Guides">Guides</h2> +<h2 id="Anleitung">Anleitung</h2> <dl> - <dt><a href="/en-US/docs/Web/CSS/Media_Queries/Using_media_queries">Using media queries</a></dt> - <dd>Presents what media queries are doing and explains the possible expressions.</dd> - <dt><a href="/en-US/docs/Web/CSS/Media_Queries/Testing_media_queries">Testing media queries</a></dt> - <dd>Explains how to test a media query programmatically, from JavaScript.</dd> + <dt><a href="/de/docs/Web/CSS/Media_Queries/Using_media_queries">Media Queries verwenden</a></dt> + <dd>Stellt Media Queries, ihre Syntax und die Operatoren und Media Features vor, die zur Konstruktion von Media Query-Ausdrücken verwendet werden.</dd> + <dt><a href="/de/docs/Web/CSS/Media_Queries/Testing_media_queries">Media Queries programmatisch testen</a></dt> + <dd>Beschreibt, wie Sie Media Queries in Ihrem JavaScript-Code verwenden, um den Zustand eines Geräts zu ermitteln und Listener einzurichten, die Ihren Code benachrichtigen, wenn sich die Ergebnisse von Media Queries ändern (z. B. wenn der Benutzer den Bildschirm dreht oder die Größe des Browsers ändert).</dd> + <dt><a href="/de/docs/Web/CSS/Media_Queries/Using_Media_Queries_for_Accessibility">Verwendung von Media Queries für Barrierefreiheit</a></dt> + <dd>Erfahren Sie, wie Media Queries dem Benutzer helfen können, Ihre Website besser zu verstehen.</dd> </dl> -<h2 id="Specifications">Specifications</h2> +<h2 id="Spezifikationen">Spezifikationen</h2> <table class="standard-table"> <thead> <tr> - <th scope="col">Specification</th> + <th scope="col">Spezifikation</th> <th scope="col">Status</th> - <th scope="col">Comment</th> + <th scope="col">Kommentar</th> </tr> </thead> <tbody> <tr> + <td>{{SpecName('CSS5 Media Queries')}}</td> + <td>{{Spec2('CSS5 Media Queries')}}</td> + <td></td> + </tr> + <tr> <td>{{SpecName('CSS3 Conditional')}}</td> <td>{{Spec2('CSS3 Conditional')}}</td> - <td> </td> + <td></td> </tr> <tr> <td>{{SpecName('CSS4 Media Queries')}}</td> <td>{{Spec2('CSS4 Media Queries')}}</td> - <td> - <p><br> - </p> - </td> + <td></td> </tr> <tr> <td>{{SpecName('CSS3 Media Queries')}}</td> <td>{{Spec2('CSS3 Media Queries')}}</td> - <td> </td> + <td></td> </tr> <tr> <td>{{SpecName('CSS2.1', 'media.html')}}</td> <td>{{Spec2('CSS2.1')}}</td> - <td> </td> + <td>Ursprüngliche Definition</td> </tr> </tbody> </table> -<h2 id="Browser_compatibility" name="Browser_compatibility">Browser compatibility</h2> +<h2 id="Siehe_auch">Siehe auch</h2> -{{Compat("css.at-rules.media")}} +<ul> + <li>Verwenden Sie {{cssxref("@supports")}}, um Stile anzuwenden, die von der Browserunterstützung für verschiedene CSS-Technologien abhängen.</li> +</ul> +</div> +</div> +</div> diff --git a/files/de/web/css/media_queries/testing_media_queries/index.html b/files/de/web/css/media_queries/testing_media_queries/index.html new file mode 100644 index 0000000000..c30abd2ccd --- /dev/null +++ b/files/de/web/css/media_queries/testing_media_queries/index.html @@ -0,0 +1,88 @@ +--- +title: Media Queries programmatisch testen +slug: Web/CSS/Media_Queries/Testing_media_queries +translation_of: Web/CSS/Media_Queries/Testing_media_queries +--- +<div>{{cssref}}</div> + +<p>The {{Glossary("DOM")}} provides features that can test the results of a <a href="/en-US/docs/Web/CSS/Media_Queries">media query</a> programmatically, via the {{domxref("MediaQueryList")}} interface and its methods and properties. Once you've created a <code>MediaQueryList</code> object, you can check the result of the query or receive notifications when the result changes.</p> + +<h2 id="Creating_a_media_query_list">Creating a media query list</h2> + +<p>Before you can evaluate the results of a media query, you need to create the <code>MediaQueryList</code> object representing the query. To do this, use the {{domxref("window.matchMedia")}} method.</p> + +<p>For example, to set up a query list that determines if the device is in landscape or portrait orientation:</p> + +<pre class="brush: js notranslate">const mediaQueryList = window.matchMedia("(orientation: portrait)"); +</pre> + +<h2 id="Checking_the_result_of_a_query">Checking the result of a query</h2> + +<p>Once you've created your media query list, you can check the result of the query by looking at the value of its <code>matches</code> property:</p> + +<pre class="brush: js notranslate">if (mediaQueryList.matches) { + /* The viewport is currently in portrait orientation */ +} else { + /* The viewport is not currently in portrait orientation, therefore landscape */ +} +</pre> + +<h2 id="Receiving_query_notifications">Receiving query notifications</h2> + +<p>If you need to be aware of changes to the evaluated result of the query on an ongoing basis, it's more efficient to register a <a href="/en-US/docs/Web/API/EventTarget/addEventListener">listener</a> than to poll the query's result. To do this, call the <code>addListener()</code> method on the {{domxref("MediaQueryList")}} object, with a callback function to invoke when the media query status changes (e.g., the media query test goes from <code>true</code> to <code>false</code>):</p> + +<pre class="brush: js notranslate">// Create the query list. +const mediaQueryList = window.matchMedia("(orientation: portrait)"); + +// Define a callback function for the event listener. +function handleOrientationChange(mql) { + // ... +} + +// Run the orientation change handler once. +handleOrientationChange(mediaQueryList); + +// Add the callback function as a listener to the query list. +mediaQueryList.addListener(handleOrientationChange); +</pre> + +<p>This code creates the orientation-testing media query list, then adds an event listener to it. After adding the listener, we also call the listener directly. This makes our listener perform adjustments based on the current device orientation; otherwise, our code might assume the device is in portrait mode at startup, even if it's actually in landscape mode.</p> + +<p>The <code>handleOrientationChange()</code> function would look at the result of the query and handle whatever we need to do on an orientation change:</p> + +<pre class="brush: js notranslate">function handleOrientationChange(evt) { + if (evt.matches) { + /* The viewport is currently in portrait orientation */ + } else { + /* The viewport is currently in landscape orientation */ + } +} +</pre> + +<p>Above, we define the parameter as <code>evt</code> — an event object. This makes sense because <a href="/en-US/docs/Web/API/MediaQueryList#Browser_compatibility">newer implementations of <code>MediaQueryList</code></a> handle event listeners in a standard way. They no longer use the unusual {{domxref("MediaQueryListListener")}} mechanism, but a standard event listener setup, passing an <a href="/en-US/docs/Web/API/Event">event object</a> of type {{domxref("MediaQueryListEvent")}} as the argument to the callback function.</p> + +<p>This event object also includes the {{domxref("MediaQueryListEvent.media","media")}} and {{domxref("MediaQueryListEvent.matches","matches")}} properties, so you can query these features of the <code>MediaQueryList</code> by directly accessing it, or accessing the event object.</p> + +<h2 id="Ending_query_notifications">Ending query notifications</h2> + +<p>To stop receiving notifications about changes to the value of your media query, call <code>removeListener()</code> on the <code>MediaQueryList</code>, passing it the name of the previously-defined callback function:</p> + +<pre class="brush: js notranslate">mediaQueryList.removeListener(handleOrientationChange); +</pre> + +<h2 id="Browser_compatibility">Browser compatibility</h2> + +<h3 id="MediaQueryList_interface"><code>MediaQueryList</code> interface</h3> + + + +<p>{{Compat("api.MediaQueryList")}}</p> + +<h2 id="See_also">See also</h2> + +<ul> + <li><a href="/en-US/docs/CSS/Media_queries">Media queries</a></li> + <li>{{domxref("window.matchMedia()")}}</li> + <li>{{domxref("MediaQueryList")}}</li> + <li>{{domxref("MediaQueryListEvent")}}</li> +</ul> diff --git a/files/de/web/css/media_queries/using_media_queries/index.html b/files/de/web/css/media_queries/using_media_queries/index.html index f4d15a6c53..77efb6a299 100644 --- a/files/de/web/css/media_queries/using_media_queries/index.html +++ b/files/de/web/css/media_queries/using_media_queries/index.html @@ -1,17 +1,19 @@ --- -title: Using media queries +title: Media Queries verwenden slug: Web/CSS/Media_Queries/Using_media_queries tags: - NeedsTranslation translation_of: Web/CSS/Media_Queries/Using_media_queries --- -<p><span class="seoSummary">A <strong>media query</strong> consists of a media type and at least one expression that limits the style sheets' scope by using media features, such as width, height, and color. Media queries, added in <a href="/en-US/docs/CSS/CSS3" title="/en-US/docs/CSS/CSS3">CSS3</a>, let the presentation of content be tailored to a specific range of output devices without having to change the content itself.</span></p> +<div>{{cssref}}</div> + +<p>A <strong>media query</strong> consists of a media type and at least one expression that limits the style sheets' scope by using media features, such as width, height, and color. Media queries, added in <a href="/en-US/docs/CSS/CSS3" title="/en-US/docs/CSS/CSS3">CSS3</a>, let the presentation of content be tailored to a specific range of output devices without having to change the content itself.</p> <h2 id="Syntax">Syntax</h2> <p>Media queries consist of a <a class="internal" href="/en-US/docs/CSS/@media" title="/en-US/docs/CSS/@media">media type</a> and can, as of the CSS3 specification, contain one or more expressions, expressed as media features, which resolve to either true or false. The result of the query is true if the media type specified in the media query matches the type of device the document is being displayed on <strong>and</strong> all expressions in the media query are true.</p> -<pre class="brush: html"><!-- CSS media query on a link element --> +<pre class="brush: html notranslate"><!-- CSS media query on a link element --> <link rel="stylesheet" media="(max-width: 800px)" href="example.css" /> <!-- CSS media query within a stylesheet --> @@ -37,15 +39,15 @@ translation_of: Web/CSS/Media_Queries/Using_media_queries <p>The <code>and</code> keyword is used for combining multiple media features together, as well as combining media features with media types. A basic media query, a single media feature with the implied <code>all</code> media type, could look like this:</p> -<pre class="brush: css">@media (min-width: 700px) { ... }</pre> +<pre class="brush: css notranslate">@media (min-width: 700px) { ... }</pre> <p>If, however, you wanted this to apply only if the display is in landscape, you could use an <code>and</code> operator to chain the media features together.</p> -<pre class="brush: css">@media (min-width: 700px) and (orientation: landscape) { ... }</pre> +<pre class="brush: css notranslate">@media (min-width: 700px) and (orientation: landscape) { ... }</pre> <p>Now the above media query will only return true if the viewport is 700px wide or wider and the display is in landscape. If, however, you only wanted this to apply if the display in question was of the media type TV, you could chain these features with a media type using an <code>and</code> operator.</p> -<pre class="brush: css">@media tv and (min-width: 700px) and (orientation: landscape) { ... }</pre> +<pre class="brush: css notranslate">@media tv and (min-width: 700px) and (orientation: landscape) { ... }</pre> <p>Now, the above media query will only apply if the media type is TV, the viewport is 700px wide or wider, and the display is in landscape.</p> @@ -55,7 +57,7 @@ translation_of: Web/CSS/Media_Queries/Using_media_queries <p>For instance, if you wanted to apply a set of styles if the viewing device either had a minimum width of 700px or was a handheld in landscape, you could write the following:</p> -<pre class="brush: css">@media (min-width: 700px), handheld and (orientation: landscape) { ... }</pre> +<pre class="brush: css notranslate">@media (min-width: 700px), handheld and (orientation: landscape) { ... }</pre> <p>Above, if I were on a <code>screen</code> device with a viewport width of 800px, the media statement would return true because the first part, interpreted as <code>@media all and (min-width: 700px)</code> would apply to my device and therefore return true, despite the fact that my <code>screen</code> device would fail the <code>handheld</code> media type check in the second media query. Likewise, if I were on a <code>handheld</code> device held in landscape with a viewport width of 500px, while the first media query would fail due to the viewport width, the second media query would succeed and thus the media statement would return true.</p> @@ -63,37 +65,37 @@ translation_of: Web/CSS/Media_Queries/Using_media_queries <p>The <code>not</code> keyword applies to the whole media query and returns true if the media query would otherwise return false (such as <code>monochrome</code> on a color display or a screen width of 600px with a <code>min-width: 700px</code> feature query). A <code>not</code> will only negate the media query it is applied to and not to every media query if present in a comma-separated list of media queries. The <code>not</code> keyword cannot be used to negate an individual feature query, only an entire media query. <span style="line-height: 1.572;">For example, the </span><code style="font-size: 14px;">not</code><span style="line-height: 1.572;"> is evaluated last in the following query:</span></p> -<pre class="brush: css" style="font-size: 14px;">@media not all and (monochrome) { ... } +<pre class="brush: css notranslate" style="font-size: 14px;">@media not all and (monochrome) { ... } </pre> <p>This means that the query is evaluated like this:</p> -<pre class="brush: css" style="font-size: 14px;">@media not (all and (monochrome)) { ... } +<pre class="brush: css notranslate" style="font-size: 14px;">@media not (all and (monochrome)) { ... } </pre> <p>... rather than like this:</p> -<pre class="brush: css" style="font-size: 14px;">@media (not all) and (monochrome) { ... }</pre> +<pre class="brush: css notranslate" style="font-size: 14px;">@media (not all) and (monochrome) { ... }</pre> <p>As another example, look at the following media query:</p> -<pre class="brush: css" style="font-size: 14px;">@media not screen and (color), print and (color) +<pre class="brush: css notranslate" style="font-size: 14px;">@media not screen and (color), print and (color) </pre> <p>It is evaluated like this:</p> -<pre class="brush: css" style="font-size: 14px;">@media (not (screen and (color))), print and (color)</pre> +<pre class="brush: css notranslate" style="font-size: 14px;">@media (not (screen and (color))), print and (color)</pre> <h4 id="only">only</h4> <p><span style="line-height: 21px;">The </span><code style="font-size: 14px;">only</code><span style="line-height: 21px;"> keyword prevents older browsers that do not support media queries with media features from applying the given styles:</span></p> -<pre class="brush: html"><link rel="stylesheet" media="only screen and (color)" href="example.css" /> +<pre class="brush: html notranslate"><link rel="stylesheet" media="only screen and (color)" href="example.css" /> </pre> -<h3 id="Pseudo-BNF_(for_those_of_you_that_like_that_kind_of_thing)">Pseudo-BNF (for those of you that like that kind of thing)</h3> +<h3 id="Pseudo-BNF_for_those_of_you_that_like_that_kind_of_thing">Pseudo-BNF (for those of you that like that kind of thing)</h3> -<pre>media_query_list: <media_query> [, <media_query> ]* +<pre class="notranslate">media_query_list: <media_query> [, <media_query> ]* media_query: [[only | not]? <media_type> [ and <expression> ]*] | <expression> [ and <expression> ]* expression: ( <media_feature> [: <value>]? ) @@ -135,12 +137,12 @@ media_feature: width | min-width | max-width <p>To apply a style sheet to all color devices:</p> -<pre class="brush: css">@media all and (color) { ... } +<pre class="brush: css notranslate">@media all and (color) { ... } </pre> <p>To apply a style sheet to devices with at least 4 bits per color component:</p> -<pre class="brush: css">@media all and (min-color: 4) { ... } +<pre class="brush: css notranslate">@media all and (min-color: 4) { ... } </pre> <h3 id="color-index">color-index</h3> @@ -155,12 +157,12 @@ media_feature: width | min-width | max-width <p>To indicate that a style sheet should apply to all devices using indexed color, you can do:</p> -<pre class="brush: css">@media all and (color-index) { ... } +<pre class="brush: css notranslate">@media all and (color-index) { ... } </pre> <p>To apply a style sheet to indexed color devices with at least 256 colors:</p> -<pre class="brush: html"><link rel="stylesheet" media="all and (min-color-index: 256)" href="http://foo.bar.com/stylesheet.css" /> +<pre class="brush: html notranslate"><link rel="stylesheet" media="all and (min-color-index: 256)" href="http://foo.bar.com/stylesheet.css" /> </pre> <h3 id="aspect-ratio">aspect-ratio</h3> @@ -175,7 +177,7 @@ media_feature: width | min-width | max-width <p>The following selects a special style sheet to use for when the display area is at least as wide as it is high.</p> -<pre class="brush: css">@media screen and (min-aspect-ratio: 1/1) { ... }</pre> +<pre class="brush: css notranslate">@media screen and (min-aspect-ratio: 1/1) { ... }</pre> <p>This selects the style when the aspect ratio is either 1:1 or greater. In other words, these styles will only be applied when the viewing area is square or landscape.</p> @@ -191,7 +193,7 @@ media_feature: width | min-width | max-width <p>The following selects a special style sheet to use for widescreen displays.</p> -<pre class="brush: css">@media screen and (device-aspect-ratio: 16/9), screen and (device-aspect-ratio: 16/10) { ... }</pre> +<pre class="brush: css notranslate">@media screen and (device-aspect-ratio: 16/9), screen and (device-aspect-ratio: 16/10) { ... }</pre> <p>This selects the style when the aspect ratio is either 16:9 or 16:10.</p> @@ -207,7 +209,7 @@ media_feature: width | min-width | max-width <p>To apply a style sheet to a document when displayed on a screen that is less than 800 pixels long, you can use this:</p> -<pre class="brush: html"><link rel="stylesheet" media="screen and (max-device-height: 799px)" /> +<pre class="brush: html notranslate"><link rel="stylesheet" media="screen and (max-device-height: 799px)" /> </pre> <h3 id="device-width">device-width</h3> @@ -222,7 +224,7 @@ media_feature: width | min-width | max-width <p>To apply a style sheet to a document when displayed on a screen that is less than 800 pixels wide, you can use this:</p> -<pre class="brush: html" style="font-size: 14px;"><link rel="stylesheet" media="screen and (max-device-width: 799px)" /></pre> +<pre class="brush: html notranslate" style="font-size: 14px;"><link rel="stylesheet" media="screen and (max-device-width: 799px)" /></pre> <h3 id="grid">grid</h3> @@ -236,7 +238,7 @@ media_feature: width | min-width | max-width <p>To apply a style to handheld devices with a 15-character or narrower display:</p> -<pre class="brush: css">@media handheld and (grid) and (max-width: 15em) { ... } +<pre class="brush: css notranslate">@media handheld and (grid) and (max-width: 15em) { ... } </pre> <div class="note"><strong>Note:</strong> The "em" unit has a special meaning for grid devices; since the exact width of an "em" can't be determined, 1em is assumed to be the width of one grid cell horizontally, and the height of one cell vertically.</div> @@ -263,12 +265,12 @@ media_feature: width | min-width | max-width <p>To apply a style sheet to all monochrome devices:</p> -<pre class="brush: css">@media all and (monochrome) { ... } +<pre class="brush: css notranslate">@media all and (monochrome) { ... } </pre> <p>To apply a style sheet to monochrome devices with at least 8 bits per pixel:</p> -<pre class="brush: css">@media all and (min-monochrome: 8) { ... } +<pre class="brush: css notranslate">@media all and (min-monochrome: 8) { ... } </pre> <h3 id="orientation">orientation</h3> @@ -283,7 +285,7 @@ media_feature: width | min-width | max-width <p>To apply a style sheet only in portrait orientation:</p> -<pre class="brush: css">@media all and (orientation: portrait) { ... }</pre> +<pre class="brush: css notranslate">@media all and (orientation: portrait) { ... }</pre> <div class="note"><strong>Note:</strong> This value does not correspond to actual device orientation. Opening the soft keyboard on most devices in portrait orientation will cause the viewport to become wider than it is tall, thereby causing the browser to use landscape styles instead of portrait.</div> @@ -299,12 +301,12 @@ media_feature: width | min-width | max-width <p>To apply a style sheet to devices with at least 300 dots per inch of resolution:</p> -<pre class="brush: css">@media print and (min-resolution: 300dpi) { ... } +<pre class="brush: css notranslate">@media print and (min-resolution: 300dpi) { ... } </pre> <p>To replace the old <span style="font-family: courier new,andale mono,monospace; line-height: normal;">(min-device-pixel-ratio: 2) </span>syntax:</p> -<pre class="brush: css">@media screen and (min-resolution: 2dppx) { ... }</pre> +<pre class="brush: css notranslate">@media screen and (min-resolution: 2dppx) { ... }</pre> <h3 id="scan">scan</h3> @@ -318,7 +320,7 @@ media_feature: width | min-width | max-width <p>To apply a style sheet only to progressive scanning televisions:</p> -<pre class="brush: css">@media tv and (scan: progressive) { ... } +<pre class="brush: css notranslate">@media tv and (scan: progressive) { ... } </pre> <h3 id="width">width</h3> @@ -335,18 +337,18 @@ media_feature: width | min-width | max-width <p>If you want to specify a style sheet for handheld devices, or screen devices with a width greater than 20em, you can use this query:</p> -<pre class="brush: css">@media handheld and (min-width: 20em), screen and (min-width: 20em) { ... } +<pre class="brush: css notranslate">@media handheld and (min-width: 20em), screen and (min-width: 20em) { ... } </pre> <p>This media query specifies a style sheet that applies to printed media wider than 8.5 inches:</p> -<pre class="brush: html"><link rel="stylesheet" media="print and (min-width: 8.5in)" +<pre class="brush: html notranslate"><link rel="stylesheet" media="print and (min-width: 8.5in)" href="http://foo.com/mystyle.css" /> </pre> <p>This query specifies a style sheet that is usable when the viewport is between 500 and 800 pixels wide:</p> -<pre class="brush: css">@media screen and (min-width: 500px) and (max-width: 800px) { ... } +<pre class="brush: css notranslate">@media screen and (min-width: 500px) and (max-width: 800px) { ... } </pre> <h2 id="Mozilla-specific_media_features">Mozilla-specific media features</h2> @@ -398,7 +400,7 @@ media_feature: width | min-width | max-width <p>Example:</p> -<pre>@media (-webkit-min-device-pixel-ratio: 2), /* Webkit-based browsers */ +<pre class="notranslate">@media (-webkit-min-device-pixel-ratio: 2), /* Webkit-based browsers */ (min--moz-device-pixel-ratio: 2), /* Older Firefox browsers (prior to Firefox 16) */ (min-resolution: 2dppx), /* The standard way */ (min-resolution: 192dpi) /* dppx fallback */ </pre> @@ -631,8 +633,6 @@ media_feature: width | min-width | max-width <p>[4] <code>tv</code> media type is not supported</p> -<p> </p> - <h2 id="See_also">See also</h2> <ul> diff --git a/files/de/web/css/media_queries/using_media_queries_for_accessibility/index.html b/files/de/web/css/media_queries/using_media_queries_for_accessibility/index.html new file mode 100644 index 0000000000..004ff3a78e --- /dev/null +++ b/files/de/web/css/media_queries/using_media_queries_for_accessibility/index.html @@ -0,0 +1,88 @@ +--- +title: Verwendung von Media Queries für Barrierefreiheit +slug: Web/CSS/Media_Queries/Using_Media_Queries_for_Accessibility +translation_of: Web/CSS/Media_Queries/Using_Media_Queries_for_Accessibility +--- +<p><strong>Media Queries</strong> can also be used to help users with disabilities understand your website better.</p> + +<h2 id="Reduced_Motion">Reduced Motion</h2> + +<p>Blinking and flashing animation can be problematic for people with cognitive concerns such as Attention Deficit Hyperactivity Disorder (ADHD). Additionally, certain kinds of motion can be a trigger for Vestibular disorders, epilepsy, and migraine and Scotopic sensitivity.</p> + +<p>Also, this method of switching animation off according to the user's preference can also benefit users with low battery or low-end phones or computers.</p> + +<h3 id="Syntax">Syntax</h3> + +<dl> + <dt><code><dfn>no-preference</dfn></code></dt> + <dd>Indicates that the user has made no preference known to the system.</dd> + <dt><code><dfn>reduce</dfn></code></dt> + <dd>Indicates that user has notified the system that they prefer an interface that minimizes the amount of movement or animation, preferably to the point where all non-essential movement is removed.</dd> +</dl> + +<h3 id="Example">Example</h3> + +<p>This example has an annoying animation unless you turn on Reduce Motion in your accessibility preferences.</p> + +<h4 id="HTML">HTML</h4> + +<pre class="brush: html notranslate"><div class="animation">animated box</div> +</pre> + +<h4 id="CSS">CSS</h4> + +<pre class="brush: css notranslate">.animation { + -webkit-animation: vibrate 0.3s linear infinite both; + animation: vibrate 0.3s linear infinite both; +} + +@media (prefers-reduced-motion: reduce) { + .animation { + animation: none; + } +} +</pre> + +<h2 id="High_Contrast_Mode">High Contrast Mode</h2> + +<div>{{CSSRef}}{{Non-standard_header}}</div> + +<p>The <strong>-ms-high-contrast</strong> <a href="/en-US/docs/Web/CSS">CSS</a> <a href="/en-US/docs/Web/CSS/Media_Queries/Using_media_queries#Media_features">media feature</a> is a <a href="/en-US/docs/Web/CSS/Microsoft_extensions">Microsoft extension</a> that describes whether the application is being displayed in high contrast mode, and with what color variation.</p> + +<p>This will help not only users with low vision and contrast sensitivity issues but also users that are working on a computer or phone with direct sunlight.</p> + +<h3 id="Syntax_2">Syntax</h3> + +<p>The <strong><code>-ms-high-contrast</code></strong> media feature is specified as one of the following values.</p> + +<h3 id="Values">Values</h3> + +<dl> + <dt><code>active</code></dt> + <dd> + <p>Indicates that the subsequent styling rules will be applied when the system is placed in high contrast mode with any color variation.</p> + </dd> + <dt><code>black-on-white</code></dt> + <dd> + <p>Indicates that the subsequent styling rules will be applied when the system is placed in high contrast mode with a black-on-white color variation.</p> + </dd> + <dt><code>white-on-black</code></dt> + <dd> + <p>Indicates that the subsequent styling rules will be applied when the system is placed in high contrast mode with a white-on-black color variation.</p> + </dd> +</dl> + +<h3 id="Example_2">Example</h3> + +<p>The following declarations will match applications that are being displayed in high contrast mode with any color variation, a black-on-white color variation, and a white-on-black color variation, respectively.</p> + +<pre class="brush: css notranslate">@media screen and (-ms-high-contrast: active) { + /* All high contrast styling rules */ +} +@media screen and (-ms-high-contrast: black-on-white) { + div { background-image: url('image-bw.png'); } +} +@media screen and (-ms-high-contrast: white-on-black) { + div { background-image: url('image-wb.png'); } +} +</pre> diff --git a/files/de/web/css/perspective-origin/index.html b/files/de/web/css/perspective-origin/index.html new file mode 100644 index 0000000000..d70e6b980a --- /dev/null +++ b/files/de/web/css/perspective-origin/index.html @@ -0,0 +1,391 @@ +--- +title: perspective-origin +slug: Web/CSS/perspective-origin +translation_of: Web/CSS/perspective-origin +--- +<div>{{CSSRef}}</div> + +<p>Die <a href="/de/docs/CSS">CSS</a>-Eigenschaft <strong><code>perspective-origin</code></strong> <a href="/en-US/docs/CSS">CSS</a> property determines the position at which the viewer is looking. It is used as the <em>vanishing point</em> by the {{cssxref("perspective")}} property.</p> + +<div>{{EmbedInteractiveExample("pages/css/perspective-origin.html")}}</div> + + + +<p>The <strong><code>perspective-origin</code> </strong>and {{cssxref('perspective')}} properties are attached to the parent of a child transformed in 3-dimensional space, unlike the <code><a href="/en-US/docs/Web/CSS/transform-function/perspective">perspective()</a></code> transform function which is placed on the element being transformed.</p> + +<h2 id="Syntax">Syntax</h2> + +<pre class="brush:css no-line-numbers notranslate">/* One-value syntax */ +perspective-origin: x-position; + +/* Two-value syntax */ +perspective-origin: x-position y-position; + +/* When both x-position and y-position are keywords, + the following is also valid */ +perspective-origin: y-position x-position; + +/* Global values */ +perspective-origin: inherit; +perspective-origin: initial; +perspective-origin: unset; +</pre> + +<h3 id="Values">Values</h3> + +<dl> + <dt><em>x-position</em></dt> + <dd>Indicates the position of the abscissa of the <em>vanishing point</em>. It can have one of the following values: + <ul> + <li>{{cssxref("<length-percentage>")}} indicating the position as an absolute length value or relative to the width of the element. The value may be negative.</li> + <li><code>left</code>, a keyword being a shortcut for the <code>0</code> length value.</li> + <li><code>center</code>, a keyword being a shortcut for the <code>50%</code> percentage value.</li> + <li><code>right</code>, a keyword being a shortcut for the <code>100%</code> percentage value.</li> + </ul> + </dd> + <dt><em>y-position</em></dt> + <dd>Indicates the position of the ordinate of the <em>vanishing point</em>. It can have one of the following values: + <ul> + <li>{{cssxref("<length-percentage>")}} indicating the position as an absolute length value or relative to the height of the element. The value may be negative.</li> + <li><code>top</code>, a keyword being a shortcut for the <code>0</code> length value.</li> + <li><code>center</code>, a keyword being a shortcut for the <code>50%</code> percentage value.</li> + <li><code>bottom</code>, a keyword being a shortcut for the <code>100%</code> percentage value.</li> + </ul> + </dd> +</dl> + +<h2 id="Formal_definition">Formal definition</h2> + +<p>{{cssinfo}}</p> + +<h2 id="Formal_syntax">Formal syntax</h2> + +<pre class="syntaxbox notranslate">{{csssyntax}}</pre> + +<h2 id="Examples">Examples</h2> + +<h3 id="Changing_the_perspective_origin">Changing the perspective origin</h3> + +<p>This example shows cubes with popular <code>perspective-origin</code> values.</p> + +<h4 id="HTML">HTML</h4> + +<pre class="brush: html notranslate"><section> + +<figure> + <figcaption><code>perspective-origin: top left;</code></figcaption> + <div class="container"> + <div class="cube potl"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: top;</code></figcaption> + <div class="container"> + <div class="cube potm"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: top right;</code></figcaption> + <div class="container"> + <div class="cube potr"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: left;</code></figcaption> + <div class="container"> + <div class="cube poml"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: 50% 50%;</code></figcaption> + <div class="container"> + <div class="cube pomm"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: right;</code></figcaption> + <div class="container"> + <div class="cube pomr"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: bottom left;</code></figcaption> + <div class="container"> + <div class="cube pobl"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: bottom;</code></figcaption> + <div class="container"> + <div class="cube pobm"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: bottom right;</code></figcaption> + <div class="container"> + <div class="cube pobr"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: -200% -200%;</code></figcaption> + <div class="container"> + <div class="cube po200200neg"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: 200% 200%;</code></figcaption> + <div class="container"> + <div class="cube po200200pos"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +<figure> + <figcaption><code>perspective-origin: 200% -200%;</code></figcaption> + <div class="container"> + <div class="cube po200200"> + <div class="face front">1</div> + <div class="face back">2</div> + <div class="face right">3</div> + <div class="face left">4</div> + <div class="face top">5</div> + <div class="face bottom">6</div> + </div> + </div> +</figure> + +</section> +</pre> + +<h4 id="CSS">CSS</h4> + +<pre class="brush: css notranslate">/* perspective-origin values (unique per example) */ +.potl { + perspective-origin: top left; +} +.potm { + perspective-origin: top; +} +.potr { + perspective-origin: top right; +} +.poml { + perspective-origin: left; +} +.pomm { + perspective-origin: 50% 50%; +} +.pomr { + perspective-origin: right; +} +.pobl { + perspective-origin: bottom left; +} +.pobm { + perspective-origin: bottom; +} +.pobr { + perspective-origin: bottom right; +} +.po200200neg { + perspective-origin: -200% -200%; +} +.po200200pos { + perspective-origin: 200% 200%; +} +.po200200 { + perspective-origin: 200% -200%; +} + +/* Define the container div, the cube div, and a generic face */ +.container { + width: 100px; + height: 100px; + margin: 24px; + border: none; +} + +.cube { + width: 100%; + height: 100%; + backface-visibility: visible; + perspective: 300px; + transform-style: preserve-3d; +} + +.face { + display: block; + position: absolute; + width: 100px; + height: 100px; + border: none; + line-height: 100px; + font-family: sans-serif; + font-size: 60px; + color: white; + text-align: center; +} + +/* Define each face based on direction */ +.front { + background: rgba(0, 0, 0, 0.3); + transform: translateZ(50px); +} +.back { + background: rgba(0, 255, 0, 1); + color: black; + transform: rotateY(180deg) translateZ(50px); +} +.right { + background: rgba(196, 0, 0, 0.7); + transform: rotateY(90deg) translateZ(50px); +} +.left { + background: rgba(0, 0, 196, 0.7); + transform: rotateY(-90deg) translateZ(50px); +} +.top { + background: rgba(196, 196, 0, 0.7); + transform: rotateX(90deg) translateZ(50px); +} +.bottom { + background: rgba(196, 0, 196, 0.7); + transform: rotateX(-90deg) translateZ(50px); +} + +/* Make the layout a little nicer */ +section { + background-color: #EEE; + padding: 10px; + font-family: sans-serif; + text-align: left; + display: grid; + grid-template-columns: repeat(3, 1fr); +}</pre> + +<h4 id="Result">Result</h4> + +<p>{{EmbedLiveSample('Changing_the_perspective_origin', '100%', 700)}}</p> + +<h2 id="Specifications">Specifications</h2> + +<table class="standard-table"> + <thead> + <tr> + <th scope="col">Specification</th> + <th scope="col">Status</th> + <th scope="col">Comment</th> + </tr> + </thead> + <tbody> + <tr> + <td>{{SpecName('CSS Transforms 2', '#perspective-origin-property', 'perspective-origin')}}</td> + <td>{{Spec2('CSS Transforms 2')}}</td> + <td>Initial definition.</td> + </tr> + </tbody> +</table> + +<h2 id="Browser_compatibility">Browser compatibility</h2> + +<div> + + +<p>{{Compat("css.properties.perspective-origin")}}</p> +</div> + +<h2 id="See_also">See also</h2> + +<ul> + <li><a href="/en-US/docs/Web/CSS/CSS_Transforms/Using_CSS_transforms">Using CSS Transforms</a></li> + <li>{{cssxref('transform-style')}}</li> + <li>{{cssxref('transform-function')}}</li> + <li>{{cssxref('perspective')}}</li> + <li><code><a href="/en-US/docs/Web/CSS/transform-function/perspective">transform: perspective()</a></code> function</li> +</ul> diff --git a/files/de/web/css/transform-function/index.html b/files/de/web/css/transform-function/index.html index 7ad06db5c7..7c0f426410 100644 --- a/files/de/web/css/transform-function/index.html +++ b/files/de/web/css/transform-function/index.html @@ -1,5 +1,5 @@ --- -title: <transform-function> +title: Transformationsfunktionen slug: Web/CSS/transform-function tags: - CSS diff --git a/files/de/web/css/transform/index.html b/files/de/web/css/transform/index.html index 3e001247e1..0456661dbb 100644 --- a/files/de/web/css/transform/index.html +++ b/files/de/web/css/transform/index.html @@ -2,122 +2,169 @@ title: transform slug: Web/CSS/transform tags: - - BrauchtBeispiele - - BrauchtBrowserKompatibilität + - CSS - CSS-Eigenschaft - Referenz + - Transfomation + - 'recipe:css-property' translation_of: Web/CSS/transform --- -<p> {{CSRef}} {{SeheCompatTable}}</p> +<div>{{CSSRef}}</div> -<p>Mit der Eigenschaft "CSS übersetzen" können Sie Übersetzungstransformationen einzeln und unabhängig von der Eigenschaft<br> - {{CSSxRef ("transform")}} angeben. Dadurch wird die typische Verwendung der Benutzeroberfläche besser abgebildet, und Sie müssen sich nicht die genaue Reihenfolge der Transformationsfunktionen merken, die im Transformationswerte angegeben werden müssen.</p> +<p>Mit der <a href="/de/docs/Web/CSS">CSS</a>-Eigenschaft <strong><code>transform</code></strong> können Sie ein Element drehen, skalieren, schräg stellen oder übersetzen. Sie modifiziert den Koordinatenraum des CSS <a href="/de/docs/Web/CSS/Visual_formatting_model">visuellen Formatierungsmodells</a>.</p> -<p>Syntax</p> +<div>{{EmbedInteractiveExample("pages/css/transform.html")}}</div> -<p>/ * Schlüsselwortwerte * / translate: none; / * Einzelwerte * / translate: 100px; übersetzen: 50%; / * Zwei Werte * / translate: 100px 200px; übersetzen: 50% 105px; / * Drei Werte * / übersetzen: 50% 105px 5rem;</p> -<p><br> - Values</p> -<p><p> {{HTMLSidebar ("Global_attributes")}} </p></p> +<p>Wenn die Eigenschaft einen anderen Wert als <code>none</code> hat, wird ein <a href="/de/docs/Web/CSS/CSS_Positioning/Understanding_z_index/The_stacking_context">Stapelkontext</a> erstellt. In diesem Fall fungiert das Element als ein enthaltender Block für alle <code>position: fixed;</code> oder <code>position: absolute;</code> Elemente, die es enthält.</p> -<p> <p> <span class = "seoSummary"> Das <strong> translate </strong> <a href="/en-US/docs/Web/HTML/Global_attributes"> globale Attribut </a> ist ein aufgezähltes Attribut, das wird verwendet, um anzugeben, ob die <em> übersetzbaren Attributwerte </em> eines Elements und die untergeordneten Knoten {{domxref ("Text")}} beim Lokalisieren der Seite übersetzt werden sollen oder ob sie unverändert bleiben sollen. </span> Es kann folgende Werte annehmen:<br> - </p></p> +<div class="warning"> +<p>Nur transformierbare Elemente können transformiert werden. Das heißt, alle Elemente, deren Layout durch das CSS-Box-Modell geregelt wird, mit Ausnahme von: <a href="/de/docs/Web/CSS/Visual_formatting_model#Inline-level_elements_and_inline_boxes">nicht ersetzten Inline-Boxen</a>, <a href="/de/docs/Web/HTML/Element/col">Tabellen-Spalten-Boxen</a> und <a href="/de/docs/Web/HTML/Element/colgroup">Tabellen-Spalten-Gruppen-Boxen</a>.</p> +</div> -<p><ul><br> - <li> leere Zeichenfolge oder <code> "yes" </code>, die angibt, dass das Element übersetzt werden soll, wenn die Seite lokalisiert wird. </i><br> - <li> <code> "no" </code> gibt an, dass das Element nicht übersetzt werden darf. </li><br> - </ul></p> +<h2 id="Syntax">Syntax</h2> -<p> <p> Obwohl nicht alle Browser dieses Attribut erkennen, wird es von automatischen Übersetzungssystemen wie Google Translate und möglicherweise auch von Tools, die von menschlichen Übersetzern verwendet werden, respektiert. Aus diesem Grund ist es wichtig, dass Webautoren dieses Attribut verwenden, um Inhalte zu markieren, die nicht übersetzt werden sollen. </P></p> +<pre class="brush: css notranslate">/* Keyword values */ +transform: none; -<p> <h2 id = "Specifications"> Spezifikationen </h2></p> +/* Function values */ +transform: matrix(1.0, 2.0, 3.0, 4.0, 5.0, 6.0); +transform: matrix3d(1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1); +transform: perspective(17px); +transform: rotate(0.5turn); +transform: rotate3d(1, 2.0, 3.0, 10deg); +transform: rotateX(10deg); +transform: rotateY(10deg); +transform: rotateZ(10deg); +transform: translate(12px, 50%); +transform: translate3d(12px, 50%, 3em); +transform: translateX(2em); +transform: translateY(3in); +transform: translateZ(2px); +transform: scale(2, 0.5); +transform: scale3d(2.5, 1.2, 0.3); +transform: scaleX(2); +transform: scaleY(0.5); +transform: scaleZ(0.3); +transform: skew(30deg, 20deg); +transform: skewX(30deg); +transform: skewY(1.07rad); -<p> <table class = "standard-table"><br> - <tbody><br> - <tr><br> - <th scope = "col"> Spezifikation </th><br> - <th scope = "col"> Status </th><br> - <th scope = "col"> Kommentar </th><br> - </tr><br> - <tr><br> - <td> {{SpecName ('HTML WHATWG', "dom.html # attr-translate", "translate")}} </td><br> - <td> {{Spec2 ('HTML WHATWG')}} </td><br> - <td> Keine Änderung gegenüber dem letzten Snapshot {{SpecName ('HTML5.1')}} </td><br> - </tr><br> - <tr><br> - <td> {{SpecName ('HTML5.1', "dom.html # the-translate-attribute", "translate")}} </td><br> - <td> {{Spec2 ('HTML5.1')}} </td><br> - <td> Momentaufnahme von {{SpecName ('HTML WHATWG')}}, ursprüngliche Definition </td><br> - </tr><br> - </tbody><br> - </table></p> +/* Multiple function values */ +transform: translateX(10px) rotate(10deg) translateY(5px); +transform: perspective(500px) translate(10px, 0, 20px) rotateY(3deg); -<p> <h2 id = "Browser_compatibility"> Browserkompatibilität </h2></p> +/* Global values */ +transform: inherit; +transform: initial; +transform: unset; +</pre> -<p> <div class = "hidden"> Die Kompatibilitätstabelle auf dieser Seite wird aus strukturierten Daten generiert. Wenn Sie zu den Daten beitragen möchten, lesen Sie <a href="https://github.com/mdn/browser-compat-data"> https://github.com/mdn/browser-compat- Daten </a> und senden Sie uns eine Pull-Anfrage. </div></p> +<p>Die Eigenschaft <code>transform</code> kann entweder als Schlüsselwortwert <code><a href="/de/docs/Web/CSS/transform$edit#none">none</a></code> oder mehrere<code><a href="/de/docs/Web/CSS/transform$edit#<transform-function>"><transform-function></a></code> -Werte angegeben werden.</p> -<p> <p> {{Compat ("html.global_attributes.translate")}} </p></p> +<div class="blockIndicator note"> +<p><strong>Hinweis:</strong> Wenn {{cssxref("transform-function/perspective", "perspective()")}} einer von mehreren Funktionswerten ist, muss er zuerst aufgeführt werden.</p> +</div> -<p> <h2 id = "See_also"> Siehe auch </h2></p> +<h3 id="Werte">Werte</h3> -<p> <ul><br> - <li> Alle <a href="/en-US/docs/Web/HTML/Global_attributes"> globalen Attribute </a>. </li><br> - <li> Die Eigenschaft {{domxref ("HTMLElement.translate")}}, die dieses Attribut widerspiegelt. </li><br> - <li> <a href="https://www.w3.org/International/questions/qa-translate-flag"> Verwenden des HTML-Übersetzungsattributs </a> </li><br> - </ul></p> +<dl> + <dt id="<transform-function>">{{cssxref("<transform-function>")}}</dt> + <dd>Eine oder mehrere der <a href="/de/docs/Web/CSS/transform-function">CSS-Transformationsfunktionen</a>, die angewendet werden sollen. Die Transformationsfunktionen werden in der Reihenfolge von links nach rechts multipliziert, was bedeutet, dass zusammengesetzte Transformationen effektiv in der Reihenfolge von rechts nach links angewendet werden.</dd> + <dt id="none"><code>none</code></dt> + <dd>Specifies that no transform should be applied.</dd> +</dl> -<p><br> - Formal syntax</p> +<h2 id="Bedenken_hinsichtlich_der_Zugänglichkeit">Bedenken hinsichtlich der Zugänglichkeit</h2> -<p>{{CSSSyntax}}</p> +<p>Skalierungs-/Zoom-Animationen sind problematisch für die Barrierefreiheit, da sie ein häufiger Auslöser für bestimmte Arten von Migräne sind. Wenn Sie solche Animationen auf Ihrer Website einbinden müssen, sollten Sie ein Steuerelement bereitstellen, mit dem Benutzer Animationen abschalten können, vorzugsweise site-wide.</p> -<p>Examples</p> +<p>Ziehen Sie außerdem in Erwägung, die Medienfunktion {{cssxref("@media/prefers-reduced-motion", "prefers-reduced-motion")}} zu nutzen - verwenden Sie sie, um eine <a href="/de/docs/Web/CSS/Media_Queries">Media Queries</a> zu schreiben, die Animationen ausschaltet, wenn der Benutzer in seinen Systemeinstellungen reduzierte Animationen angegeben hat.</p> -<p>HTML</p> +<p>Erfahren Sie mehr:</p> -<p><div><br> - <p class="translate"> Translation<br> - </p> </div></p> +<ul> + <li><a href="https://wiki.developer.mozilla.org/en-US/docs/Web/Accessibility/Understanding_WCAG/Operable#Guideline_2.3_%E2%80%94_Seizures_and_Physical_Reactions_Do_not_design_content_in_a_way_that_is_known_to_cause_seizures_or_physical_reactions">MDN Understanding WCAG, Guideline 2.3 explanations</a></li> + <li><a href="https://www.w3.org/WAI/WCAG21/Understanding/animation-from-interactions">Understanding Success Criterion 2.3.3 | W3C Understanding WCAG 2.1</a></li> +</ul> -<p>CSS</p> +<h2 id="Formale_Definition">Formale Definition</h2> -<p>* { box-sizing: border-box; } html { font-family: sans-serif; } div { width: 150px; margin: 0 auto; } p { padding: 10px 5px; border: 3px solid black; border-radius: 20px; width: 150px; font-size: 1.2rem; text-align: center; } .translate { transition: translate 1s; } div:hover .translate { translate: 200px 50px; }</p> +<p>{{CSSInfo}}</p> -<p>Result</p> +<h2 id="Formale_Syntax">Formale Syntax</h2> -<p>{{EmbedLiveSample<br> - ('Examples')}}</p> +<pre class="syntaxbox notranslate">{{csssyntax}}</pre> -<p>Specifications</p> +<h2 id="Beispiel">Beispiel</h2> -<p>SpecificationStatusComment{{SpecName('CSS Transforms 2', '#individual-transforms', 'individual transforms')}}{{Spec2('CSS Transforms 2')}}Initial definition.</p> +<h3 id="Translating_and_rotating_an_element" name="Translating_and_rotating_an_element">Verschieben und Drehen eines Elements</h3> -<p>{{CSSInfo}}</p> +<h4 id="HTML">HTML</h4> + +<pre class="brush: html notranslate"><div>Transformed element</div></pre> + +<h4 id="CSS">CSS</h4> + +<pre class="brush: css notranslate">div { + border: solid red; + transform: translate(30px, 20px) rotate(20deg); + width: 140px; + height: 60px; +}</pre> -<p>Browser-Kompatibilität</p> +<h4 id="Ergebnis">Ergebnis</h4> -<p>Die Kompatibilitätstabelle auf dieser Seite wird aus strukturierten Daten generiert. Wenn Sie zu den Daten beitragen möchten, lesen Sie bitte https://github.com/mdn/browser-compat-data und senden Sie uns eine Pull-Anfrage.<br> - {{Compat("css.properties.translate")}}</p> +<p>{{EmbedLiveSample("Translating_and_rotating_an_element", "400", "160")}}</p> -<p> Siehe auch</p> +<h3 id="Mehr_Beispiele">Mehr Beispiele</h3> -<p>{{cssxref ('scale')}}</p> +<p>Weitere Beispiele finden Sie unter <a href="/de/docs/Web/CSS/CSS_Transforms/CSS_Transformationen_verwenden">Verwendung von CSS-Transformationen</a> und {{cssxref("<transform-function>")}}.</p> -<p>{{cssxref ('rotate')}}</p> +<ul> +</ul> -<p>{{cssxref ('transform')}}</p> +<h2 id="Spezifikationen">Spezifikationen</h2> -<p>hinweis: skew ist kein unabhängiger Transformationswert</p> +<table class="standard-table"> + <thead> + <tr> + <th scope="col">Spezifikation</th> + <th scope="col">Status</th> + <th scope="col">Kommentar</th> + </tr> + </thead> + <tbody> + <tr> + <td>{{SpecName('CSS Transforms 2', '#transform-functions', 'transform')}}</td> + <td>{{Spec2('CSS Transforms 2')}}</td> + <td>Zusätzliche 3D Transformationsfunctionen.</td> + </tr> + <tr> + <td>{{SpecName('CSS3 Transforms', '#transform-property', 'transform')}}</td> + <td>{{Spec2('CSS3 Transforms')}}</td> + <td>Ursprünglich Definition.</td> + </tr> + </tbody> +</table> -<p><br> - Übersetzung in Deutsch:</p> +<h2 id="Browser-Kompatibilität">Browser-Kompatibilität</h2> -<p>Benötigen Sie Hilfe? • Leitfaden für Redakteure • Stilleitfaden</p> +<div class="hidden">Die Kompatibilitätstabelle auf dieser Seite wird aus strukturierten Daten generiert. Wenn Sie zu den Daten beitragen möchten, besuchen Sie bitte <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> und senden Sie uns eine Pull-Anfrage.</div> -<p>Sie haben einen Entwurf vom: 21.10.2019 16:52:53.</p> +<p>{{Compat("css.properties.transform")}}</p> -<p>Entwurf automatisch gespeichert: 21.10.2019 16:55:27</p> +<h2 id="Siehe_auch">Siehe auch</h2> -<p> </p> +<ul> + <li><a href="/de/docs/CSS/Using_CSS_transforms">Verwendung von CSS-Transformationen</a></li> + <li>{{cssxref("<transform-function>")}} Datentyp mit allen Transformationsfunktionen erklärt.</li> + <li>Online-Tool zur Visualisierung von CSS Transformationsfunktionen: <a href="https://css-transform.moro.es/">CSS Transform Playground</a></li> + <li>{{cssxref ('matrix')}}</li> + <li>{{cssxref ('matrix3d')}}</li> + <li>{{cssxref ('perspective')}}</li> + <li>{{cssxref ('rotate')}}</li> + <li>{{cssxref ('scale')}}</li> + <li>{{cssxref ('skew')}}</li> +</ul> diff --git a/files/de/web/css/vertical-align/index.html b/files/de/web/css/vertical-align/index.html index 15729838cd..e401376bca 100644 --- a/files/de/web/css/vertical-align/index.html +++ b/files/de/web/css/vertical-align/index.html @@ -12,9 +12,7 @@ translation_of: Web/CSS/vertical-align <p>Die <a href="/de/docs/Web/CSS">CSS</a> Eigenschaft <strong><code>vertical-align</code></strong> bestimmt die vertikale Ausrichtung in inline Elementen oder in Tabellenzellen.</p> -<div>{{EmbedInteractiveExample("pages/css/vertical- -<div>align.html")}}</div> - +<div>{{EmbedInteractiveExample("pages/css/vertical-align.html")}} <div class="hidden">Die Quelle für dieses interaktive Beispiel ist in einem GitHub-Repository gespeichert. Wenn Sie zum Projekt der interaktiven Beispiele beitragen möchten, klonen Sie bitte <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples</a> und senden Sie uns eine Pull-Anfrage.</div> </div> @@ -209,8 +207,6 @@ img.middle { vertical-align: middle; } <h2 id="Spezifikation">Spezifikation</h2> - - <table class="standard-table"> <thead> <tr> diff --git a/files/de/web/css/visual_formatting_model/index.html b/files/de/web/css/visual_formatting_model/index.html new file mode 100644 index 0000000000..01c9f8a5b9 --- /dev/null +++ b/files/de/web/css/visual_formatting_model/index.html @@ -0,0 +1,144 @@ +--- +title: CSS Visuelles Formatierungsmodell +slug: Web/CSS/Visual_formatting_model +translation_of: Web/CSS/Visual_formatting_model +--- +<div>{{CSSRef}}</div> + +<p class="summary">In CSS The <strong>Visual Formatting Model</strong> describes how user agents take the document tree, and process and display it for visual media. This includes {{glossary("continuous media")}} such as a computer screen and {{glossary("paged media")}} such as a book or document printed by browser print functions. Most of the information applies equally to continuous and paged media.</p> + +<p>In the visual formatting model, each element in the document tree generates zero or more boxes according to the box model. The layout of these boxes is governed by:</p> + +<ul> + <li>Box dimensions and type.</li> + <li>Positioning scheme (normal flow, float, and absolute positioning).</li> + <li>Relationships between elements in the document tree.</li> + <li>External information (e.g., viewport size, intrinsic dimensions of images, etc.).</li> +</ul> + +<p>Much of the information about the visual formatting model is defined in CSS2, however, various level 3 specifications have added to this information. When reading specifications you will often find references to the model as defined in CSS2, so an understanding of the model and the terms used to describe it in CSS2 is valuable when reading other layout specifications.</p> + +<p>In this document we define the model and introduce some of the related terms and concepts, linking to more specific pages on MDN for further details.</p> + +<h2 id="The_role_of_the_viewport">The role of the viewport</h2> + +<p>In continuous media, the {{glossary("viewport")}} is the viewing area of the browser window. User agents can change the layout of the page when the viewport size changes — for example, if you resize your window, or change the orientation of a mobile device.</p> + +<p>If the viewport is smaller than the size of the document then the user agent needs to offer a way to scroll to the parts of the document that are not displayed. We most often see this as scrolling in the <strong>block dimension</strong> — vertically in a horizontal, top-to-bottom language. However, you might design something that requires scrolling in the <strong>inline dimension</strong> too.</p> + +<h2 id="Box_generation">Box generation</h2> + +<p><strong>Box generation</strong> is the part of the CSS visual formatting model that creates boxes from the document's elements. Generated boxes are of different types, which affect their visual formatting. The type of the box generated depends on the value of the CSS {{cssxref("display")}} property.</p> + +<p>Initially defined in CSS2, the <code>display</code> property is extended in the <a href="https://www.w3.org/TR/css-display-3/">CSS Display Module Level 3</a>. In addition, some of the terminologies around the display have been updated and clarified in the years since CSS2.</p> + +<p>CSS takes your source document and renders it onto a canvas. To do this, it generates an intermediary structure, the <strong>box tree</strong>, which represents the formatting structure of the rendered document. Each box in the box tree represents its corresponding element (or pseudo-element) in space and/or time on the canvas, while each text run in the box tree likewise represents the contents of its corresponding text nodes.</p> + +<p>Then, for each element, CSS generates zero or more boxes as specified by that element’s <code>display</code> property value.</p> + +<div class="blockIndicator note"> +<p><strong>Note</strong>: Boxes are often referred to by their display type — e.g. a box generated by an element with <code>display: block</code> is called a "block box" or just a "block". Note however that block boxes, block-level boxes and box containers are all subtly different; see the {{anch("Block boxes")}} section below for more details.</p> +</div> + +<h3 id="The_principal_box">The principal box</h3> + +<p>When an element generates one or more boxes, one of them is the <strong>principal box</strong>, which contains its descendant boxes and generated content in the box tree, and is also the box involved in any positioning scheme.</p> + +<p>Some elements may generate additional boxes in addition to the principal box, for example <code>display: list-item</code> generates more than one box (e.g. a <strong>principal block box</strong> and a <strong>child marker box</strong>). And some values (such as <code>none</code> or <code>contents</code>) cause the element and/or its descendants to not generate any boxes at all.</p> + +<h3 id="Anonymous_boxes">Anonymous boxes</h3> + +<p>An <strong>anonymous box</strong> is created when there is not an HTML element to use for the box. This situation happens when, for example, you declare <code>display: flex</code> on a parent element, and directly inside there is a run of text not contained in another element. In order to fix the box tree, an anonymous box is created around that run of text. It will then behave as a flex item, however, it cannot be targeted and styled like a regular box because there is no element to target.</p> + +<p>{{EmbedGHLiveSample("css-examples/visual-formatting/anonymous-flex.html", '100%', 720)}}</p> + +<p>The same thing happens when you have text runs interspersed with block elements. In the next example I have a string inside a <code><div></code>; in the middle of my string is a <code><p></code> element containing part of the text.</p> + +<p>{{EmbedGHLiveSample("css-examples/visual-formatting/anonymous-block.html", '100%', 720)}}</p> + +<p>The string is split into three boxes in the box tree. The part of the string before the paragraph element is wrapped in an anonymous box, then we have the <code><p></code>, which generates a box, and then another anonymous box.</p> + +<p>Something to consider about these anonymous boxes is that they inherit styles from their direct parent, but you cannot change how they look by targeting the anonymous box. In my examples, I am using a direct child selector to target the children of the container. This does not change the anonymous boxes, as they are not a child of the parent block.</p> + +<p><strong>Inline anonymous boxes</strong> are created when a string is split by an inline element, for example, a sentence that includes a section wrapped with <code><em></em></code>. This splits the sentence into three inline boxes — an anonymous inline box before the emphasized section, the section wrapped in the <code><em></code> element, then a final anonymous inline box. As with the anonymous block boxes, these anonymous inline boxes cannot be styled independently in the way the <code><em></code> can; they just inherit the styles of their container.</p> + +<p>Other formatting contexts also create anonymous boxes. <a href="/en-US/docs/Web/CSS/CSS_Grid_Layout">Grid Layout</a> behaves in the same way as the <a href="/en-US/docs/Web/CSS/CSS_Flexible_Box_Layout">flexbox</a> example above, turning strings of text into a grid item with an anonymous box. <a href="/en-US/docs/Web/CSS/CSS_Columns">Multiple-column</a> layout creates anonymous column boxes around the columns; these also cannot be styled or otherwise targetted. <a href="/en-US/docs/Web/CSS/CSS_Table">Table layout</a> will add anonymous boxes to create a proper table structure — for example adding an anonymous table row — if there was no box with <code>display: table-row</code>.</p> + +<h3 id="Line_boxes">Line boxes</h3> + +<p><strong>Line boxes</strong> are the boxes that wrap each line of text. You can see the difference between line boxes and their containing block if you float an item and then follow it by a block that has a background color.</p> + +<p>In the following example, the line boxes following the floated <code><div></code> are shortened to wrap around the float. The background of the box runs behind the float, as the floated item has been taken out of flow.</p> + +<p>{{EmbedGHLiveSample("css-examples/visual-formatting/line-boxes.html", '100%', 720)}}</p> + +<h2 id="Positioning_schemes_and_in-flow_and_out-of-flow_elements">Positioning schemes and in-flow and out-of-flow elements</h2> + +<p>In CSS, a box may be laid out according to three positioning schemes — <strong>normal flow</strong>, <strong>floats</strong>, or <strong>absolute positioning</strong>.</p> + +<h3 id="Normal_flow">Normal flow</h3> + +<p>In CSS, the normal flow includes block-level formatting of block boxes, inline-level formatting of inline boxes, and also includes relative and sticky positioning of block-level and inline-level boxes.</p> + +<p>Read more about <a href="/en-US/docs/Web/CSS/CSS_Flow_Layout">flow layout</a> in CSS.</p> + +<h3 id="Floats">Floats</h3> + +<p>In the float model, a box is first laid out according to the normal flow, then taken out of the flow and positioned, typically to the left or right. Content may flow along the side of a float.</p> + +<p>Find out more about <a href="/en-US/docs/Learn/CSS/CSS_layout/Floats">floats</a>.</p> + +<h3 id="Absolute_positioning">Absolute positioning</h3> + +<p>In the absolute positioning model (which also includes fixed positioning), a box is removed from the normal flow entirely and assigned a position with respect to a containing block (which is the viewport in the case of fixed positioning).</p> + +<p>An element is called <strong>out of flow</strong> if it is floated, absolutely positioned, or is the root element. An element is called <strong>in-flow</strong> if it is not out of the flow.</p> + +<p>Read about <a href="/en-US/docs/Web/CSS/CSS_Positioning">CSS Positioned Layout</a>.</p> + +<h2 id="Formatting_contexts_and_the_display_property">Formatting contexts and the display property</h2> + +<p>Boxes can be described as having an <strong>outer display type</strong>, which is <code>block</code> or <code>inline</code>. This outer display type refers to how the box behaves alongside other elements on the page.</p> + +<p>Boxes also have an inner display type, dictating how their children behave. For normal block and inline layout, or normal flow, this display type is <code>flow</code>. This means that the child elements will also be either <code>block</code> or <code>inline</code>.</p> + +<p>However, the inner display type might be something like <code>grid</code> or <code>flex</code>, in which case the direct children will display as a grid, or flex items. In such a case the element is described as creating a grid or flex <a href="/en-US/docs/Web/CSS/CSS_Flow_Layout/Intro_to_formatting_contexts">formatting context</a>. In many ways this is similar to a block formatting context, however, the children behave as flex or grid items rather than items in normal flow.</p> + +<p>The interactions between block-level and inline-level boxes are described in the MDN documentation for {{cssxref("display")}}.</p> + +<p>In addition, the references for specific values of display explain how these formatting contexts work in terms of box layout.</p> + +<ul> + <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout">CSS Grid Layout</a></li> + <li><a href="/en-US/docs/Web/CSS/CSS_Flexible_Box_Layout">CSS Flexible Box Layout</a></li> + <li><a href="/en-US/docs/Web/CSS/CSS_Table">CSS Table Layout</a></li> + <li><a href="/en-US/docs/Web/CSS/CSS_Lists_and_Counters">Lists</a></li> +</ul> + +<h3 id="Independent_formatting_contexts">Independent formatting contexts</h3> + +<p>Elements either participate in the formating context of their containing block or establish an independent formatting context. A grid container, for example, establishes a new <strong>Grid Formatting Context</strong> for its children.</p> + +<p><strong>Independent formatting contexts</strong> contain floats, and margins do not collapse across formatting context boundaries. Therefore, creating a new block formatting context can ensure that floats remain inside a box. Developers sometimes clear floats by changing the value of the {{cssxref("overflow")}} property, as this creates a new block formatting context. The newer value of <code>display: flow-root</code> creates a new <a href="/en-US/docs/Web/Guide/CSS/Block_formatting_context">block formatting context</a> in order to gain the useful effects of this, without any unwanted issues caused by changing the value of overflow.</p> + +<h3 id="Block_boxes">Block boxes</h3> + +<p>In specifications, block boxes, block-level boxes, and block containers are all referred to as <strong>block boxes</strong> in certain places. These things are somewhat different and the term block box should only be used if there is no ambiguity.</p> + +<h4 id="Block_containers">Block containers</h4> + +<p>A <strong>block container</strong> either contains only inline-level boxes participating in an inline formatting context, or only block-level boxes participating in a block formatting context. For this reason, we see the behavior explained above, where anonymous boxes are introduced to ensure all of the items can participate in a block or inline formatting context. An element is a block container only if it contains block-level or inline-level boxes.</p> + +<h4 id="Inline-level_and_block-level_boxes">Inline-level and block-level boxes</h4> + +<p>These are the boxes contained inside the block container that are participating in inline or block layout, respectively.</p> + +<h4 id="Block_boxes_2">Block boxes</h4> + +<p>A block box is a block-level box that is also a block container. As described in CSS <code>display</code>, it is possible for a box to be a block-level box, but not also a block container (it might be a flex or grid container for example).</p> + +<h2 id="See_also">See also</h2> + +<ul> + <li>{{css_key_concepts}}</li> +</ul> |