--- title: Object.is() slug: Web/JavaScript/Reference/Global_Objects/Object/is tags: - ECMAScript 2015 - Experimental - Expérimental(2) - Method - Object translation_of: Web/JavaScript/Reference/Global_Objects/Object/is --- <div>{{JSRef("Global_Objects", "Object")}}</div> <h2 id="Zusammenfassung">Zusammenfassung</h2> <p>Die <code><strong>Object.is()</strong></code> Methode entscheidet, ob zwei Werte <a href="/en-US/docs/Web/JavaScript/Guide/Sameness">die gleichen Werte sind</a>.</p> <h2 id="Syntax" name="Syntax">Syntax</h2> <pre class="syntaxbox"><code>var <var>isSame</var> = Object.is(<var>value1</var>, <var>value2</var>);</code></pre> <h3 id="Parameters" name="Parameters">Parameter</h3> <dl> <dt><code>value1</code></dt> <dd>Der erste Wert zum vergleichen.</dd> <dt><code>value2</code></dt> <dd>Der zweite Wert zum vergleichen.</dd> </dl> <h2 id="Beschreibung">Beschreibung</h2> <p><span class="short_text" id="result_box" lang="en"><span><code>Object.is()</code> bestimmt, ob zwei Werte <a href="/en-US/docs/Web/JavaScript/Guide/Sameness" title="/en-US/docs/Web/JavaScript/Guide/Sameness"><dfn>gleich sind</dfn></a>. </span></span><span class="short_text" lang="en"><span>Dabei gelten zwei Werte genau dann als gleich, wenn eine der folgenden Bedingungen zutrifft:</span></span></p> <ul> <li><span class="short_text" lang="en"><span>beide sind <code>undefined</code></span></span></li> <li><span class="short_text" lang="en"><span>beide sind <code>null</code></span></span></li> <li><span class="short_text" lang="en"><span>beide sind <code>true</code> oder beide sind <code>false</code></span></span></li> <li><span class="short_text" lang="en"><span>beide sind Strings mit selber Länge und den selben Zeichen</span></span></li> <li><span class="short_text" lang="en"><span>beide sind das selbe Objekt</span></span></li> <li><span class="short_text" lang="en"><span>beide sind Zahlen und eine der folgenden Bedingungen trifft zu:</span></span> <ul> <li>beide sind <code>+0</code></li> <li>beide sind <code>-0</code></li> <li>beide sind <code>NaN</code></li> <li>beide sind nicht Null, beide sind nicht <code>NaN</code> und beide haben den selben Zahlenwert</li> </ul> </li> </ul> <p>Dies ist <em>nicht</em> das selbe wie der <code>==</code>-Operator. Dieser verwendet verschiedene, situationsabhängige Typ-Umwandlungen auf beiden Seiten bevor auf Gleichheit getestet wird (was z.B. dazu führt, dass der Ausdruck <code>"" == false</code> zu <code>true</code> ausgewertet wird). <code>Object.is</code> hingegen wandelt keinen der beiden Werte um.</p> <p>Es ist ebenfalls nicht das selbe wie der strikte <code>===</code>-Operator. Dieser – ebenso wie der <code>==</code>-Operator – behandelt zum Beispiel <code>+0</code> und <code>-0</code> als identisch während <code>NaN</code> und <code>NaN</code> als nicht identisch behandelt werden.</p> <h2 id="Beispiele">Beispiele</h2> <pre class="brush: js">Object.is('foo', 'foo'); // true Object.is(window, window); // true Object.is('foo', 'bar'); // false Object.is([], []); // false var test = { a: 1 }; Object.is(test, test); // true Object.is(null, null); // true // Special Cases Object.is(0, -0); // false Object.is(-0, -0); // true Object.is(NaN, 0/0); // true </pre> <h2 id="Polyfill">Polyfill</h2> <p><code>Object.</code> ist eine vorgeschlagene Ergänzung des ECMA-262 Standard; als solcher könnte dieser nicht von allen Browser verstanden werden. Du kannst drum herum arbeiten, indem du den folgenden Code an den Anfang deines Scripts packst. Das erlaubt dir die <code>Object.is Methode</code> zu verwenden, auch wenn es keine eingebaute Unterstützung dafür gibt.</p> <pre><code>if (!Object.is) { Object.is = function(x, y) { // SameValue algorithm if (x === y) { // Steps 1-5, 7-10 // Steps 6.b-6.e: +0 != -0 return x !== 0 || 1 / x === 1 / y; } else { // Step 6.a: NaN == NaN return x !== x && y !== y; } }; }</code></pre> <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('ES2015', '#sec-object.is', 'Object.is')}}</td> <td>{{Spec2('ES2015')}}</td> <td>Initial definition.</td> </tr> </tbody> </table> <h2 id="Browserkompatibilität">Browserkompatibilität</h2> <div> <p>{{Compat("javascript.builtins.Object.is")}}</p> </div> <h2 id="Siehe_auch">Siehe auch</h2> <ul> <li><a href="/en-US/docs/Web/JavaScript/Guide/Sameness">JavaScript Guide: Sameness</a> — ein Vergleich aller drei eingebauten Gleichheitseinrichtungen</li> </ul>