js雙等號探索(三): [] == false爲True,而!![] == false爲False ?

[] == false; //爲True
!![] == false; //爲False
複製代碼

1、[] == false爲True

第一步 轉成[] == 0

根據 MDN Web 文檔-比較操做符:developer.mozilla.org/zh-CN/docs/…javascript

0.png

若是其中一個操做數爲布爾類型,那麼布爾操做數若是爲true,那麼會轉換爲1,若是爲false,會轉換爲整數0,即0。 因此![]false0.java

[] == 0
複製代碼

第二步 轉成"" == 0

根據 MDN Web 文檔-比較操做符:developer.mozilla.org/zh-CN/docs/…git

image.png

若是一個對象與數字或字符串相比較,JavaScript會嘗試返回對象的默認值。操做符會嘗試經過方法valueOf和toString將對象轉換爲其原始值(一個字符串或數字類型的值)。 因此[].valueOf().toString()""github

"" == 0
複製代碼

第三步 轉成0 == 0

根據 MDN Web 文檔-比較操做符:developer.mozilla.org/zh-CN/docs/…app

image.png

當比較數字和字符串時,字符串會轉換成數字值。 JavaScript 嘗試將數字字面量轉換爲數字類型的值。 Number("")0ui

0 == 0
複製代碼

最後0==0True,因此[] == falseTurespa

2、!![] == false爲False

第一步 先運行!![]

根據 MDN Web 文檔-運算符優先級:developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/Operator_Precedence 設計

感嘆號.png

等號.png

!的優先級爲16 ,==的優先級爲10!的優先級更高,因此先運行!![]code

!![]
複製代碼

第二步 先運行!false

根據 **《Javascript高級程序設計》**這本書第44頁中邏輯非的說明: cdn

!.jpeg

若是操做數是一個對象,返回false

因此運行!false,爲True

!false //爲True
複製代碼

最後true == falseFalse,因此!![] == falseFalse

[] == falseTrue!![] == falseFalse

其餘連接

Happy coding ..

相關文章
相關標籤/搜索