?js中toString()函數(shù)與valueOf()函數(shù)使用與區(qū)別
一、??前言
在等于運算符中,如果比較的內容包含對象類型數(shù)據(jù),則會涉及隱式轉換,那么就會調用toString()函數(shù)和valueOf()函數(shù),下面我們將會了解到關于這兩個函數(shù)的基本概念和使用場景。
二、toString() 函數(shù)
toString() 函數(shù)的作用是把一個邏輯值轉換為字符串,并返回結果。
console.log((1).toString());//1
console.log((10).toString(2))//1010
console.log(("1").toString());//1
console.log((false).toString());//false
console.log(({p:1}).toString());//[object,object]
console.log((undefined).toString());//報錯
console.log((null).toString());//報錯
console.log((function(){}).toString());//function(){}
console.log([1,2,3,4].toString());//1,2,3,4
console.log((new Date()).toString())//Fri Jul 03 2020 17:20:11 GMT+0800 (中國標準時間)
在JavaScript中,Object,Array,F(xiàn)unction,Date等類型都實現(xiàn)了自定義的toString()函數(shù)。
- Object 類型數(shù)據(jù)的 toString() 函數(shù)默認的返回結果是 "[object Object]",當我們自定義新的類時,可以重寫 toString() 函數(shù),返回可讀性更高的結果。
- Array 的 toString() 函數(shù)返回值為以逗號分隔構成的數(shù)組成員字符串。數(shù)組也是對象,那么為什么數(shù)組返回的是對應的字符串而不是對象,其實數(shù)組覆蓋了Object.toString方法,然后將連接數(shù)組并返回一個字符串,其中包含用逗號分隔的每個數(shù)組元素(相當于Array.join())
- Function 的 toString() 函數(shù)返回值為函數(shù)的文本定義
- Date 的 toString() 函數(shù)返回值為具有可讀性的時間字符串
三、valueOf()函數(shù)
valueOf() 函數(shù)的作用是返回最適合引用類型的原始值,如果沒有原始值,則會返回引用類型自身。
console.log((1).valueOf());//1
console.log((10).valueOf(2))//報錯
console.log(("1").valueOf());//1
console.log((false).valueOf());//false
console.log(({p:1}).valueOf());//{p:1}
console.log((undefined).valueOf());//報錯
console.log((null).valueOf());//報錯
console.log((function(){}).valueOf());//function(){}
console.log([1,2,3,4].valueOf());//[1,2,3,4]
console.log((new Date()).valueOf());//1593767848260
- Object 類型數(shù)據(jù)的valueOf()函數(shù)默認的返回結果是"{}",即一個空的對象字面量。
- Array 的valueOf()函數(shù)返回的是數(shù)組本身
- function 的valueOf()函數(shù)返回的是函數(shù)本身
- Date 的valueOf()函數(shù)返回的是指定日期的時間戳
小結:
- toString() 返回的是字符串,而 valueOf() 返回的是原始值,沒有原始值返回對象本身
- undefined 和 null 都沒有 toString() 和 valueOf() 方法
- Date 類型的 toString() 返回的表示時間的字符串;valueOf() 返回的是現(xiàn)在到1970年1月1日的毫秒數(shù)(時間戳)
- Number 類型的 toString() 方法可以接收轉換基數(shù),返回不同進制的字符串形式的數(shù)值;而 valueOf()方 法無法接受轉換基數(shù)
四、特殊情況
如果一個引用類型的值既存在 toString() 函數(shù)又存在 valueOf() 函數(shù),那么在做隱式轉換時,會調用哪個函數(shù)呢?這里我們可以概括成兩種場景,分別是引用類型轉換為 String 類型,以及引用類型轉換為 Number 類型。
1、引用類型轉換為 String 類型
一個引用類型的數(shù)據(jù)在轉換為 String 類型時,一般是用于數(shù)據(jù)展示,轉換時遵循以下規(guī)則:
- 如果對象具有 toString() 函數(shù),則會優(yōu)先調用 toString() 函數(shù)。如果它返回的是一個原始值,則會直接將這個原始值轉換為字符串表示,并返回該字符串。
- 反之,則會再去調用 valueOf() 函數(shù),如果 valueOf() 函數(shù)返回的結果是一個原始值,則會將這個結果轉換為字符串表示,并返回該字符串。
- 如果通過 toString() 函數(shù)或者 valueOf() 函數(shù)都無法獲得一個原始值,則會直接拋出類型轉換異常。
2、引用類型轉換為 Number 類型
一個引用類型的數(shù)據(jù)在轉換為 Number 類型時,一般是用于數(shù)據(jù)運算,轉換時遵循以下規(guī)則:
- 如果對象具有 valueOf() 函數(shù),則會優(yōu)先調用 valueOf() 函數(shù),如果 valueOf() 函數(shù)返回一個原始值,則會直接將這個原始值轉換為數(shù)字表示,并返回該數(shù)字。
- 反之,則會再去調用 toString() 函數(shù),如果 toString() 函數(shù)返回的結果是一個原始值,則會將這個結果轉換為數(shù)字表示,并返回該數(shù)字。
- 如果通過 toString() 函數(shù)或者 valueOf() 函數(shù)都無法獲得一個原始值,則會直接拋出類型轉換異常。
到此這篇關于 js中toString()函數(shù)與valueOf()函數(shù)使用與區(qū)別的文章就介紹到這了,更多相關 js toString()函數(shù)與valueOf()函數(shù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
JavaScript和TypeScript中的void的具體使用
這篇文章主要介紹了JavaScript和TypeScript中的void的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-09-09
關于ckeditor在bootstrap中modal中彈框無法輸入的解決方法
今天小編就為大家分享一篇關于ckeditor在bootstrap中modal中彈框無法輸入的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09

