Javascript隱式轉換怎麼用? (程式碼範例)
本篇文章帶給大家的內容是關於Javascript隱式轉換怎麼用? (程式碼範例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。
確定兩個變數是否相等是程式設計中的一個非常重要的操作。
在比較字串、數值和布林值的相等性時,問題還比較簡單。但在涉及到物件的比較時,問題就變得複雜了。最早的 ECMAScript 中的相等與不等 操作符會在執行比較之前,先將物件轉換成相似的型別。後來,有人提出了這種轉換到底是否合理的質疑。
最後,ECMAScript 的解決方案就是提供兩組運算子:
相等且不相等-先轉換再比較,全等和不全等-只比較而不轉換。
這裡我們只對相等做一些討論。
"==" 相等時的隱式轉換
對於"==" 運算子,通常都會先隱式轉換(強制轉換),然後再比較它們的相等性。
隱含轉換規則:
1.如果有一個運算元是布林值,則在比較相等性之前先將其轉換為數值— —false 轉換為0,而true轉換為1;
2.如果一個操作數是字串,另一個操作數是數值,在比較相等性之前先將字串轉換為數值;
字串轉換為數值:
(1)數字類型的字串,會被轉換成對應十進位的數值;
(2)空字串會轉換成0;
(3 )其餘的全都會轉換為NaN;(NaN 與任何值都不相等,包括自身)
3.如果一個操作數是對象,另一個操作數不是,則調用對象的valueOf()方法,用得到的基本類型值按照前面的規則進行比較;
下面可以透過一個簡單的例子來看JS 底層的轉換規則。
// 根据隐式转换规则第三条 调用对象的 valueOf 方法 [].valueOf() // [] // 这时就变成 [] == false ,又回到原来的情况,这时JS底层又是怎么处理的呢? // 其实 JS 的底层在调用 valueOf 得到的返回结果如果不是原始值时,就会调用对象的 toString 方法将对象转换成字符串。对于这个过程我们可以通过一下的例子来验证。 [].valueOf() // [] [].toString() // '' //上面是 这两个方法的 默认行为,在下面的例子中我们不改变默认行为 [].__proto__.valueOf = () => { console.log('valueOf'); return []; } [].__proto__.toString = () => { console.log('toString'); return ''; } [] == false // 运行的结果为 valueOf toString true // 这样就验证了上述的说明 // 我们还可以通过下面的方式,从侧面在次验证 JS底层默认的转换行为 [].__proto__.valueOf = () => { console.log('valueOf'); return ''; } [].__proto__.toString = () => { console.log('toString'); return ''; } [] == false // valueOf true [].__proto__.valueOf = () => { console.log('valueOf'); return []; } [].__proto__.toString = () => { console.log('toString'); return []; } [] == false // JS 报错 Uncaught TypeError: Cannot convert object to primitive value
現在我們可以來看看範例中 空物件為什麼不等於 false?從正常的角度來講,數組就是一個對象,為什麼空數組等於 false,而空對象為什麼和 false 不相等?
//现在我们可以参照上面隐式转换的过程,对空对象手动的执行这个过程,结果如下 ({}).valueOf() // {} ({}).toString() // '[object Object]' // 这时我们发现 空对象 与 空数组默认行为的区别了,在 toString 方法上,由于数组会对继承自对象的 toString 方法进行重写,将数组中的每个元素通过 ',' 链接成一个字符串 // 这时就变成了 '[object Object]' == false // 根据规则第二条,得到最后结果 false
隱含轉換的特殊規則:
#null 和 undefined 是相等的。
要比較相等性之前,不能將 null 和 undefined 轉換成其他任何值。
如果有一個運算元是 NaN,則相等運算子傳回 false,而不相等運算子傳回 true。
如果兩個運算元都是對象,則比較它們是不是同一個物件。 (比較引用類型的位址是否相同)
null == undefined // true NaN == NaN // false NaN != NaN // true false == 0 // true undefined == 0 // true null == 0 // true
以上是Javascript隱式轉換怎麼用? (程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript中的HTTP狀態碼取得方法簡介:在進行前端開發中,我們常常需要處理與後端介面的交互,而HTTP狀態碼就是其中非常重要的一部分。了解並取得HTTP狀態碼有助於我們更好地處理介面傳回的資料。本文將介紹使用JavaScript取得HTTP狀態碼的方法,並提供具體程式碼範例。一、什麼是HTTP狀態碼HTTP狀態碼是指當瀏覽器向伺服器發起請求時,服務
