diff options
author | Peter Bengtsson <mail@peterbe.com> | 2020-12-08 14:41:15 -0500 |
---|---|---|
committer | Peter Bengtsson <mail@peterbe.com> | 2020-12-08 14:41:15 -0500 |
commit | 4b1a9203c547c019fc5398082ae19a3f3d4c3efe (patch) | |
tree | d4a40e13ceeb9f85479605110a76e7a4d5f3b56b /files/de/web/api/keyboardevent/getmodifierstate/index.html | |
parent | 33058f2b292b3a581333bdfb21b8f671898c5060 (diff) | |
download | translated-content-4b1a9203c547c019fc5398082ae19a3f3d4c3efe.tar.gz translated-content-4b1a9203c547c019fc5398082ae19a3f3d4c3efe.tar.bz2 translated-content-4b1a9203c547c019fc5398082ae19a3f3d4c3efe.zip |
initial commit
Diffstat (limited to 'files/de/web/api/keyboardevent/getmodifierstate/index.html')
-rw-r--r-- | files/de/web/api/keyboardevent/getmodifierstate/index.html | 247 |
1 files changed, 247 insertions, 0 deletions
diff --git a/files/de/web/api/keyboardevent/getmodifierstate/index.html b/files/de/web/api/keyboardevent/getmodifierstate/index.html new file mode 100644 index 0000000000..75b1c5e36d --- /dev/null +++ b/files/de/web/api/keyboardevent/getmodifierstate/index.html @@ -0,0 +1,247 @@ +--- +title: KeyboardEvent.getModifierState() +slug: Web/API/KeyboardEvent/getModifierState +translation_of: Web/API/KeyboardEvent/getModifierState +--- +<p>{{APIRef("DOM Events")}}</p> + +<p>Die Methode <code><strong>KeyboardEvent.getModifierState()</strong></code> gibt den aktuellen Zustand des angegebenen Modifikators zurück: <code>true</code>, wenn der Modifikator aktiv ist (d.h. die Modifikationstasten gedrückt oder gesperrt ist), ansonsten <code>false</code>.</p> + +<h2 id="Syntax">Syntax</h2> + +<pre class="syntaxbox">var <code><em>active</em> = <em>event</em>.getModifierState(<em>keyArg</em>);</code></pre> + +<h3 id="Rückgabe">Rückgabe </h3> + +<p>Einen {{jsxref("Boolean")}}</p> + +<h3 id="Parameter">Parameter</h3> + +<dl> + <dt><em><code>keyArg</code></em></dt> + <dd>Ein Modifikatorschlüsselwert. Der Wert muss einer der {{domxref("KeyboardEvent.key")}} Werte sein, die Modifikatorschlüssel darstellen, oder die Zeichenkette "Accel" {{deprecated_inline}}. Dabei wird zwischen Groß- und Kleinschreibung unterschieden.</dd> +</dl> + +<h2 id="Modifikationstasten_im_Internet_Explorer">Modifikationstasten im Internet Explorer</h2> + +<p>IE9 verwendet <code>"Scroll"</code> für <code>"ScrollLock"</code> und <code>"Win"</code> für <code>"OS"</code>.</p> + +<h2 id="Modifikationstasten_in_Gecko">Modifikationstasten in Gecko</h2> + +<table style="width: 100%;"> + <caption>Wann gibt getModifierState() bei Gecko true zurück?</caption> + <thead> + <tr> + <th scope="row"> </th> + <th scope="col">Windows</th> + <th scope="col">Linux (GTK)</th> + <th scope="col">Mac</th> + <th scope="col">Android 2.3</th> + <th scope="col">Android 3.0 und später</th> + </tr> + </thead> + <tbody> + <tr> + <th scope="row"><code>"Alt"</code></th> + <td>Entweder die <kbd>Alt</kbd> oder <kbd>AltGr</kbd> -Taste gedrückt wird</td> + <td><kbd>Alt</kbd> -Taste gedrückt wird</td> + <td><kbd>⌥ Option</kbd> -Taste gedrückt wird</td> + <td colspan="2" rowspan="1"><kbd>Alt</kbd> oder <kbd>option</kbd> -Taste gedrückt wird</td> + </tr> + <tr> + <th scope="row"><code>"AltGraph"</code></th> + <td> + <p>Sowohl die <kbd>Alt</kbd> als auch die <kbd>Strg</kbd> werden gedrückt, oder die <kbd>AltGr</kbd> Taste wird gedrückt</p> + </td> + <td><kbd>Level 3 Shift</kbd> Taste (or <kbd>Level 5 Shift</kbd> Taste {{gecko_minversion_inline("20.0")}}) wird gedrückt</td> + <td><kbd>⌥ Option</kbd> Taste wird gedrückt</td> + <td colspan="2" rowspan="1" style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + </tr> + <tr> + <th scope="row"><code>"CapsLock"</code></th> + <td colspan="3" style="text-align: center;">Während die LED für <kbd>⇪ Caps Lock</kbd> leuchtet</td> + <td style="text-align: center; background-color: rgb(204, 204, 204);"><em>Nicht unterstützt</em></td> + <td>Solange <kbd>⇪ Caps Lock</kbd> gesperrt ist {{gecko_minversion_inline("29.0")}}</td> + </tr> + <tr> + <th scope="row"><code>"Control"</code></th> + <td>Entweder die <kbd>Strg</kbd> oder <kbd>AltGr</kbd> -Taste wird gedrückt</td> + <td><kbd>Strg</kbd> Taste wird gedrückt</td> + <td><kbd>control</kbd> Taste wird gedrückt</td> + <td><kbd>menu</kbd> Taste wird gedrückt.</td> + <td><kbd>Strg</kbd>, <kbd>control</kbd> oder <kbd>menu</kbd> Taste wird gedrückt.</td> + </tr> + <tr> + <th scope="row"><code>"Fn"</code></th> + <td colspan="4" style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + <td>Die <kbd>Function</kbd> wird gedrückt, aber wir sind nicht sicher, welche Taste den Modifikatorstatus aktiv setzt. Die <kbd>Fn</kbd>-Taste auf der Mac-Tastatur bewirkt dies nicht.<br> + {{gecko_minversion_inline("29.0")}}</td> + </tr> + <tr> + <th scope="row"><code>"FnLock"</code></th> + <td colspan="5" rowspan="1" style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + </tr> + <tr> + <th scope="row"><code>"Hyper"</code></th> + <td colspan="5" style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + </tr> + <tr> + <th scope="row"><code>"Meta"</code></th> + <td style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + <td style="text-align: center;"><kbd>Meta</kbd> Taste wird gedrückt {{gecko_minversion_inline("17.0")}}</td> + <td><kbd>⌘ Command</kbd> Taste wird gedrückt</td> + <td style="text-align: center; background-color: rgb(204, 204, 204);"><em>Nicht unterstützt</em></td> + <td><kbd>⊞ Windows Logo</kbd> or <kbd>command</kbd> Taste gedrückt wird</td> + </tr> + <tr> + <th scope="row"><code>"NumLock"</code></th> + <td colspan="2" style="text-align: center;">Während die LED für <kbd>Num Lock</kbd> leuchtet</td> + <td>Eine Taste auf dem Nummerblock gedrückt wird</td> + <td style="text-align: center; background-color: rgb(204, 204, 204);"><em>Nicht unterstützt</em></td> + <td>Solange <kbd>NumLock</kbd> gesperrt ist {{gecko_minversion_inline("29.0")}}</td> + </tr> + <tr> + <th scope="row"><code>"OS"</code></th> + <td><kbd>⊞ Windows Logo</kbd> Taste wird gedrückt</td> + <td><kbd>Super</kbd> or <kbd>Hyper</kbd> Taste wird gedrückt (normalerweise auf der <kbd>⊞ Windows Logo</kbd> Taste zugeordnet)</td> + <td colspan="3" rowspan="1" style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + </tr> + <tr> + <th scope="row"><code>"ScrollLock"</code></th> + <td>Während die LED für <kbd>ScrollLock</kbd> leuchtet</td> + <td>Während die LED für <kbd>ScrollLock</kbd> leuchtet, aber normalerweise wird dies von der Plattform nicht unterstützt </td> + <td colspan="2" style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + <td>Solange <kbd>ScrollLock</kbd> gesperrt {{gecko_minversion_inline("29.0")}}</td> + </tr> + <tr> + <th scope="row"><code>"Shift"</code></th> + <td colspan="5" rowspan="1" style="text-align: center;"><kbd>⇧ Shift</kbd> Taste wird gedrückt</td> + </tr> + <tr> + <th scope="row"><code>"Super"</code></th> + <td colspan="5" style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + </tr> + <tr> + <th scope="row"><code>"Symbol"</code></th> + <td colspan="5" style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + </tr> + <tr> + <th scope="row"><code>"SymbolLock"</code></th> + <td colspan="5" style="background-color: rgb(204, 204, 204); text-align: center;"><em>Nicht unterstützt</em></td> + </tr> + </tbody> +</table> + +<ul> + <li>Auf den anderen Plattformen werden <kbd>Alt</kbd>, <kbd>Control</kbd> und <kbd>Shift</kbd> unterstützt werden.</li> + <li>Alle Modifikatoren (außer "FnLock", "Hyper", "Super" und "Symbol", die nach der Implementierung von Gecko definiert werden) stehen immer für nicht vertrauenswürdige Ereignisse auf Gecko zur Verfügung. Das hängt nicht von der Plattform ab.</li> +</ul> + +<h2 id="Accel_virtueller_Modifikator"><code>"Accel"</code> virtueller Modifikator</h2> + +<div class="note"><strong>Notiz</strong><strong>:</strong> Der virtuelle Modifikator <code>"Accel"</code> ist in den aktuellen Entwürfen der DOM3 Events-Spezifikation praktisch <strong>veraltet</strong>.</div> + +<p><code>getModifierState()</code> also accepts a deprecated virtual modifier named <code>"Accel"</code>. <code>event.getModifierState("Accel")</code> returns <code>true</code> when at least one of {{domxref("KeyboardEvent.ctrlKey")}} or {{domxref("KeyboardEvent.metaKey")}} is <code>true</code>.</p> + +<p>In old implementations and outdated specifications, it returned <code>true</code> when a modifier which is the typical modifier key for the shortcut key is pressed. For example, on Windows, pressing <kbd>Ctrl</kbd> key may make it return <code>true</code>. However, on Mac, pressing <kbd>⌘ Command</kbd> key may make it return <code>true</code>. Note that which modifier key makes it return true depends on platforms, browsers, and user settings. For example, Firefox users can customize this with a pref, <code>"ui.key.accelKey"</code>.</p> + +<h2 id="Beispiel">Beispiel</h2> + +<pre class="brush: js">// Ignorieren, wenn folgender Modifikator aktiv ist. +if (event.getModifierState("Fn") || + event.getModifierState("Hyper") || + event.getModifierState("OS") || + event.getModifierState("Super") || + event.getModifierState("Win") /* hack for IE */) { + return; +} + +// auch ignorieren, wenn zwei oder mehr Modifikatoren außer Shift aktiv sind. +if (event.getModifierState("Control") + + event.getModifierState("Alt") + + event.getModifierState("Meta") > 1) { + return; +} + +// Tastaturkürzel mit Standardmodifikator +if (event.getModifierState("Accel")) { + switch (event.key.toLowerCase()) { + case "c": + if (event.getModifierState("Shift")) { + // Handle Accel + Shift + C + event.preventDefault(); // consume the key event + } + break; + case "k": + if (!event.getModifierState("Shift")) { + // Handle Accel + K + event.preventDefault(); // consume the key event + } + break; + } + return; +} + +// Mach etwas anderes für die Pfeiltasten, wenn ScrollLock gesperrt ist. +if ((event.getModifierState("ScrollLock") || + event.getModifierState("Scroll") /* hack for IE */) && + !event.getModifierState("Control") && + !event.getModifierState("Alt") && + !event.getModifierState("Meta")) { + switch (event.key) { + case "ArrowDown": + case "Down": // Hack für IE und älteren Gecko + event.preventDefault(); // Schlüsselereignis verwenden + break; + case "ArrowLeft": + case "Left": // Hack für IE und älteren Gecko + // Mach etwas anderes für die Pfeiltasten, wenn ScrollLock gesperrt ist. + event.preventDefault(); // Schlüsselereignis verwenden + break; + case "ArrowRight": + case "Right": // Hack für IE und älteren Gecko + // Mach etwas anderes für die Pfeiltasten, wenn ScrollLock gesperrt ist. + event.preventDefault(); // Schlüsselereignis verwenden + break; + case "ArrowUp": + case "Up": // Hack für IE und älteren Gecko + // Mach etwas anderes für die Pfeiltasten, wenn ScrollLock gesperrt ist. + event.preventDefault(); // Schlüsselereignis verwenden + break; + } +} +</pre> + +<div class="note"> +<p>Obwohl dieses Beispiel <code>.getModifierState()</code> mit <code>"Alt"</code>, <code>"Control"</code>, <code>"Meta"</code> und <code>"Shift"</code> verwendet, ist es vielleicht besser, <code>altKey</code>, <code>ctrlKey</code>, <code>metaKey</code> und <code>shiftKey</code> zu verwenden, da sie kürzer und vielleicht schneller sind.</p> +</div> + +<h2 id="Spezifikationen">Spezifikationen</h2> + +<table class="standard-table"> + <tbody> + <tr> + <th scope="col">Spezifikation</th> + <th scope="col">Status</th> + <th scope="col">Kommentar</th> + </tr> + <tr> + <td>{{SpecName('DOM3 Events', '#widl-KeyboardEvent-getModifierState', 'getModifierState()')}}</td> + <td>{{Spec2('DOM3 Events')}}</td> + <td>Initiale Definition (<a href="https://dvcs.w3.org/hg/dom3events/raw-file/tip/html/DOM3Events-key.html#keys-modifier">Modifier Keys spec</a>)</td> + </tr> + </tbody> +</table> + +<h2 id="Browser-Kompatibilität">Browser-Kompatibilität</h2> + +<div class="hidden">Die Kompatibilitätstabelle auf dieser Seite wird aus strukturierten Daten generiert. Wenn Du zu den Daten beitragen möchtest, besuche bitte <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> und sende uns deinen Pull-Request. </div> + +<p>{{Compat("api.KeyboardEvent.getModifierState")}}</p> + +<h2 id="Siehe_auch">Siehe auch</h2> + +<ul> + <li>Das {{domxref("KeyboardEvent")}}, zu dem die Methode gehört.</li> + <li>{{domxref("MouseEvent.getModifierState")}}</li> +</ul> |