文字列値を比較するときは常に === (三重等号、厳密な比較) を使い始めるつもりでしたが、今では
"foo" === new String("foo")
は false で、これと同じです:
var f = "foo", g = new String("foo");
f === g; // false
もちろん:
f == g; // true
では、文字列比較には常に == を使用するか、比較する前に常に変数を文字列に変換することをお勧めしますか?
文字列値を比較するときは常に === (三重等号、厳密な比較) を使い始めるつもりでしたが、今では
"foo" === new String("foo")
は false で、これと同じです:
var f = "foo", g = new String("foo");
f === g; // false
もちろん:
f == g; // true
では、文字列比較には常に == を使用するか、比較する前に常に変数を文字列に変換することをお勧めしますか?
"foo"
文字列プリミティブです。(この概念は C# や Java には存在しません)
new String("foo")
ボックス化された文字列オブジェクトです。
===
オペレータは、プリミティブとオブジェクトで異なる動作をします。
(同じタイプの) プリミティブを比較するとき===
、両方が同じ値を持つ場合は true を返します。
オブジェクトを比較するとき===
、それらが同じオブジェクトを参照している場合にのみ true を返します (参照による比較)。したがって、new String("a") !== new String("a")
.
あなたの場合、===
オペランドのタイプが異なるため、 false を返します(一方はプリミティブで、もう一方はオブジェクトです)。
プリミティブはオブジェクトではありません。オペレータはプリミティブに対して戻りませ
ん。typeof
"object"
プリミティブのプロパティに (オブジェクトとして使用して) アクセスしようとすると、Javascript 言語はそれをオブジェクトにボックス化し、毎回新しいオブジェクトを作成します。これは仕様書に記載されています。
これが、プリミティブにプロパティを配置できない理由です。
var x = "a";
x.property = 2;
alert(x.property) //undefined
を記述するたびx.property
に、異なるボックス化String
されたオブジェクトが作成されます。
を使用して===
、
Object は、それ自体への別の参照を除いて、何にも等しいことはありません。
タイプと値が同じである場合、プリミティブは別のプリミティブと比較して同等です。
このnew
言葉はここでは犯罪者です(いつものように、私は言うかもしれません)...
を使用すると、オブジェクトnew
を操作したいという希望を明示的に表現します。それはあなたにとって驚くべきことかもしれませんが、これは:
var x = new String('foo');
var y = new String('foo');
x === y;
...あなたに強力なものを与えるでしょうfalse
。簡単です。比較されるのはオブジェクトの内部ではなく、オブジェクトの参照です。もちろん、2つの異なるオブジェクトが作成されたため、これらは等しくありません。
おそらく使用したいのは変換です:
var x = String('foo');
var y = String('foo');
x === y;
...そしてそれは結果としてあなたに期待通りにあなたを与えるでしょうtrue
、それであなたはあなたの平等でfoos
永遠に喜びそして繁栄することができます。)。
foo
は純粋な文字列でnew String("foo")
あり、オブジェクト文字列です
node.js REPL(インストールされている場合はコマンドラインの「ノード」)から:
> "foo" === (new String("foo")).valueOf()
true
> "foo" === new String("foo")
false
> typeof("foo")
'string'
> typeof(new String("foo"))
'object'
> typeof((new String("foo")).valueOf())
'string'