javaScript中兩個(gè)等于號(hào)和三個(gè)等于號(hào)之間的區(qū)別介紹
一言以蔽之:==先轉(zhuǎn)換類型再比較,===先判斷類型,如果不是同一類型直接為false。
===表示恒等于,比較的兩邊要絕對(duì)的相同
alert(0 == ""); // true alert(0 == false); // true alert("" == false); // true
alert(0 === ""); // false alert(0 === false); // false alert("" === false); // false
先說 ===,這個(gè)比較簡單,具體比較規(guī)則如下:
1、如果類型不同,就[不相等]
2、如果兩個(gè)都是數(shù)值,并且是同一個(gè)值,那么[相等];(!例外)的是,如果其中至少一個(gè)是NaN,那么[不相等]。(判斷一個(gè)值是否是NaN,只能用isNaN()來判斷)
3、如果兩個(gè)都是字符串,每個(gè)位置的字符都一樣,那么[相等];否則[不相等]。
4、如果兩個(gè)值都是true,或者都是false,那么[相等]。
5、如果兩個(gè)值都引用同一個(gè)對(duì)象或函數(shù),那么[相等];否則[不相等]。
6、如果兩個(gè)值都是null,或者都是undefined,那么[相等]。
再說 ==,具體比較規(guī)則如下:
1、如果兩個(gè)值類型相同,進(jìn)行 === 比較,比較規(guī)則同上
2、如果兩個(gè)值類型不同,他們可能相等。根據(jù)下面規(guī)則進(jìn)行類型轉(zhuǎn)換再比較:
a、如果一個(gè)是null、一個(gè)是undefined,那么[相等]。
b、如果一個(gè)是字符串,一個(gè)是數(shù)值,把字符串轉(zhuǎn)換成數(shù)值再進(jìn)行比較。
c、如果任一值是 true,把它轉(zhuǎn)換成 1 再比較;如果任一值是 false,把它轉(zhuǎn)換成 0 再比較。
d、如果一個(gè)是對(duì)象,另一個(gè)是數(shù)值或字符串,把對(duì)象轉(zhuǎn)換成基礎(chǔ)類型的值再比較。對(duì)象轉(zhuǎn)換成基礎(chǔ)類型,利用它的toString或者valueOf方法。js核心內(nèi)置類,會(huì)嘗試valueOf先于toString;例外的是Date,Date利用的是toString轉(zhuǎn)換。非js核心的對(duì)象,令說(比較麻煩,我也不大懂)
e、任何其他組合(array數(shù)組等),都[不相等]。
相關(guān)文章
定義JavaScript二維數(shù)組采用定義數(shù)組的數(shù)組來實(shí)現(xiàn)
javaScript沒有提供直接定義二維數(shù)組的方法,但可以使用定義數(shù)組的數(shù)組來定義JavaScript二維數(shù)組,需要的朋友可以了解下2012-12-12javascript 基礎(chǔ)簡介 適合新手學(xué)習(xí)
在網(wǎng)絡(luò)或書籍所說的JavaScript大部分指客戶端JavaScript。2009-09-09ECMAScript6的新特性箭頭函數(shù)(Arrow Function)詳細(xì)介紹
這篇文章主要介紹了ECMAScript6的新特性箭頭函數(shù)(Arrow Function)詳細(xì)介紹,ECMAScript6其實(shí)就是JavaScript,它的新特性就是JS的新特性,引入只是時(shí)間問題,需要的朋友可以參考下2014-06-06超級(jí)給力的JavaScript的React框架入門教程
這篇文章主要介紹了JavaScript的React框架入門教程,目前React框架正被Facebook開源極力推廣中,此文強(qiáng)烈推薦!需要的朋友可以參考下2015-07-07中文路徑導(dǎo)致unitpngfix.js不正常的解決方法
本篇文章是對(duì)中文路徑導(dǎo)致unitpngfix.js不正常的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06javascript parseInt 函數(shù)分析(轉(zhuǎn))
javascript的parseInt函數(shù)的一些問題分析2009-03-03推薦JavaScript實(shí)現(xiàn)繼承的最佳方式
本文是介紹了實(shí)用call方法結(jié)合原型鏈方法來實(shí)現(xiàn)javascript繼承的最佳方式,非常的實(shí)用,有需要的小伙伴可以參考下2014-11-11