目次
準備知識
===演算子
1. x の型が未定義の場合、NaN を返します。 2. x の型が Null の場合は 0 を返し、x の型が true の場合は 1 を返し、
{} == !{}
ホームページ ウェブフロントエンド jsチュートリアル jsの==、===、Object.js()の内容を詳しく解説(総合)

jsの==、===、Object.js()の内容を詳しく解説(総合)

Sep 17, 2018 pm 03:02 PM
javascript

この記事では、js の ==、=== および Object.js() について詳しく説明します。必要な方は参考にしていただければ幸いです。

この記事では主に、JavaScript の 3 つの等価演算、==、===、Object.js() について説明します。比較と事例を通じてみんなの感動を深め、個別の事例を詳しく解説。

準備知識

ECMAScript7仕様におけるToPrimitive抽象演算の知識の詳細説明(例)

===演算子

x === y の場合、この演算子の比較手順は次のとおりです。

1. x の型が y の型と異なる場合は、false を返します。 x の型が数値の場合:

a. x が NaN の場合は false を返し、y が NaN の場合は false を返します。 x と y が同じ数値の場合は true を返し、x が 0 で y が -0 の場合は true を返します。 0 の場合は true を返します。

f は false を返します。SameValueNonNumber(x, y) の結果を返します。

SameValueNonNumber(x, y) 抽象演算は、2 つの非数値を比較し、同じ型の x と y が等しいかどうかを比較します。 比較手順は次のとおりです。 x が null または未定義の場合、true を返します。x が文字列型の場合、

x と y がまったく同じ文字エンコーディング シーケンスの場合は true を返し、それ以外の場合は false を返します。

##3 、x がブール型の場合、

#4。x と y が両方とも true または false の場合は true を返し、それ以外の場合は false を返します。シンボル タイプ

x と y が同じシンボル値の場合は true を返し、それ以外の場合は false を返します。x と y が同じオブジェクト値の場合は true を返し、そうでない場合は false を返します。間違い。

注意すべき点は、NaN、0、-0 です:

NaN === NaN // false
+0 === -0 // true
-0 === +0 // true
ログイン後にコピー

これら 3 つの例は、x === y 比較ステップの 2.1、2.4、および 2.5 にそれぞれ対応します。これら 3 つの例の出力結果は仕様の定義に完全に一致しています。これは仕様の定義に理由はありません。仕様がこのように定義されている理由については、仕様の作成者に問い合わせる必要があるかもしれませんが、これはこの記事の範囲外です。

Object.is()

Object.is(x, y) の場合、比較には抽象操作 SameValue(x, y) が使用されます。この抽象操作の手順は次のとおりです。

1. x の型が y の型と異なる場合は、

##2 を返します。 #a. x と y が両方とも NaN の場合は true を返し、x が 0 で y が -0 の場合は false を返します。 0 の場合は false を返し、

d が同じ数値の場合は true を返し、

e の場合は false を返します。 SameValueNonNumber(x, y)。

=== と Object.is() の違いは、NaN と符号付き 0 の処理にあることがわかります。 x == y、この演算子の比較手順は次のとおりです:

1. x と y が同じ型の場合、x === y の結果を返します。 . x が null で、y が未定義の場合は true を返します。x が未定義で y が数値の場合は true を返します。 y の型が文字列の場合、x == ToNumber(y) の結果を返します。x の型が文字列で、y の型が数値の場合は、ToNumber の結果を返します。 (x) == y;

6. x の型がブール型の場合、y の型の場合は ToNumber(x) == y; の結果を返します。がブール型の場合、x == ToNumber(y) の結果を返します。x の型が文字列、数値、またはシンボルのいずれかで、y の型がオブジェクトの場合は、 x == ToPrimitive(y) の結果

9. x がオブジェクトであり、y の型が文字列、数値、またはシンボルのいずれかの場合、ToPrimitive(x) == の結果。 y が返されます。

#10. false を返します。

メソッド ToNumber は上記で使用されており、ToNumber(x) の手順は次のとおりです。

1. x の型が未定義の場合、NaN を返します。 2. x の型が Null の場合は 0 を返し、x の型が true の場合は 1 を返し、

# の場合は 0 を返します。 ##4. x の型が数値の場合、x を返します。x の型が文字列の場合、この記事ではこの内容は紹介しません。詳細;

6. x の型がシンボルの場合は、NaN が返されます。 primValue の値は ToPrimitive(x, ヒント Number);

b. ToNumber(primValue) の結果を返します ;

[] == ![]

比較== 演算子の手順については上で説明しましたので、理解を深めるために例について説明します。

NaN === NaN // false
+0 === -0 // true
-0 === +0 // true
Object.is(NaN, NaN) // true
Object.is(+0, -0) // false
Object.is(-0, +0) // false
ログイン後にコピー
まず、左側の [] は空の配列、型はオブジェクト、右側は ![] です。 , [] は true 値であるため、![] の結果は false になります:

[] == ![]
ログイン後にコピー
その後、x == y 比較ステップに進みます。ステップ 7 で、x == ToNumber( の結果を返します。 y)、つまり:

[] == ![] // => [] == false
ログイン後にコピー
ToNumber(x) のステップ 3 から、ToNumber(false) が 0 を返すことがわかります:

[] == false // => [] == ToNumber(false)
ログイン後にコピー
次に、x == y のステップ 9 に進みます。比較ステップを実行し、ToPrimitive(x) == y の比較結果を返します:

[] == ToNumber(false) // => [] == +0
ログイン後にコピー
ToPrimitive([]) の結果は空の文字列 "" です。理由を説明してください。記事の ToPrimitive 抽象操作を確認してください。 ECMAScript7仕様。したがって、上記は次と同等です:

[] == +0 // => ToPrimitive([]) == +0
ログイン後にコピー
次に、x == y 比較ステップのステップ 5 に進み、ToNumber(x) == y の結果を返します。
"" == +0 // => ToNumber("") == +0
ログイン後にコピー

由ToNumber操作的第5步可知,ToNumber("")的结果是+0,所以也就是:

+0 == +0 // true
ログイン後にコピー

{} == !{}

首先,左边是{},类型是对象,右边是!{},{}是真值,所以!{}是false:

{} == !{} // => {} == false
ログイン後にコピー

然后同样会走到x == y比较步骤的第7步,返回x == ToNumber(y)的结果,也就是:

{} == false // => {} == ToNumber(false)
ログイン後にコピー

由ToNumber(x)的第3步可知,ToNumber(false)返回+0:

{} == ToNumber(false) // => {} == +0
ログイン後にコピー

然后走到x == y比较步骤的第9步,返回ToPrimitive(x) == y的比较结果:

{} == +0 // => ToPrimitive({}) == +0
ログイン後にコピー

ToPrimitive({})的结果是字符串"[object Object]",原因请查看文章ECMAScript7规范中的ToPrimitive抽象操作。所以,上面等价于:

"[object Object]" == +0
ログイン後にコピー

然后走到x == y比较步骤的第5步,返回ToNumber(x) == y的结果:

"[object Object]" == +0 // => ToNumber("[object Object]") == +0
ログイン後にコピー

由ToNumber操作的第5步可知,ToNumber("[object Object]")的结果是NaN,所以也就是:

NaN == +0 // false
ログイン後にコピー

所以,[] == ![]的结果是true,{} == !{}的结果是false。可能有人第一次看到[] == ![]的时候,觉得这个的比较结果怎么可能是true。我觉得有时候不要感性的去认识问题,按照规定的运算步骤走一遍,结果是什么就是什么。

总结

本文讲解了JavaScript中的三种相等运算:==,===和Object.js(),希望对大家有所帮助。

以上がjsの==、===、Object.js()の内容を詳しく解説(総合)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 Dec 17, 2023 pm 02:54 PM

WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 はじめに: 技術の継続的な発展により、音声認識技術は人工知能の分野の重要な部分になりました。 WebSocket と JavaScript をベースとしたオンライン音声認識システムは、低遅延、リアルタイム、クロスプラットフォームという特徴があり、広く使用されるソリューションとなっています。この記事では、WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法を紹介します。

WebSocket と JavaScript: リアルタイム監視システムを実装するための主要テクノロジー WebSocket と JavaScript: リアルタイム監視システムを実装するための主要テクノロジー Dec 17, 2023 pm 05:30 PM

WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

JavaScript と WebSocket を使用してリアルタイムのオンライン注文システムを実装する方法 JavaScript と WebSocket を使用してリアルタイムのオンライン注文システムを実装する方法 Dec 17, 2023 pm 12:09 PM

JavaScript と WebSocket を使用してリアルタイム オンライン注文システムを実装する方法の紹介: インターネットの普及とテクノロジーの進歩に伴い、ますます多くのレストランがオンライン注文サービスを提供し始めています。リアルタイムのオンライン注文システムを実装するには、JavaScript と WebSocket テクノロジを使用できます。 WebSocket は、TCP プロトコルをベースとした全二重通信プロトコルで、クライアントとサーバー間のリアルタイム双方向通信を実現します。リアルタイムオンラインオーダーシステムにおいて、ユーザーが料理を選択して注文するとき

WebSocketとJavaScriptを使ったオンライン予約システムの実装方法 WebSocketとJavaScriptを使ったオンライン予約システムの実装方法 Dec 17, 2023 am 09:39 AM

WebSocket と JavaScript を使用してオンライン予約システムを実装する方法 今日のデジタル時代では、ますます多くの企業やサービスがオンライン予約機能を提供する必要があります。効率的かつリアルタイムのオンライン予約システムを実装することが重要です。この記事では、WebSocket と JavaScript を使用してオンライン予約システムを実装する方法と、具体的なコード例を紹介します。 1. WebSocket とは何ですか? WebSocket は、単一の TCP 接続における全二重方式です。

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 Dec 17, 2023 pm 05:13 PM

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは

簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 Jan 05, 2024 pm 06:08 PM

JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

JavaScriptでinsertBeforeを使用する方法 JavaScriptでinsertBeforeを使用する方法 Nov 24, 2023 am 11:56 AM

使用法: JavaScript では、insertBefore() メソッドを使用して、DOM ツリーに新しいノードを挿入します。このメソッドには、挿入される新しいノードと参照ノード (つまり、新しいノードが挿入されるノード) の 2 つのパラメータが必要です。

JavaScript と WebSocket: 効率的なリアルタイム画像処理システムの構築 JavaScript と WebSocket: 効率的なリアルタイム画像処理システムの構築 Dec 17, 2023 am 08:41 AM

JavaScript は Web 開発で広く使用されているプログラミング言語であり、WebSocket はリアルタイム通信に使用されるネットワーク プロトコルです。 2 つの強力な機能を組み合わせることで、効率的なリアルタイム画像処理システムを構築できます。この記事では、JavaScript と WebSocket を使用してこのシステムを実装する方法と、具体的なコード例を紹介します。まず、リアルタイム画像処理システムの要件と目標を明確にする必要があります。リアルタイムの画像データを収集できるカメラ デバイスがあるとします。

See all articles