亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js中toString()與valueOf()的使用

 更新時間:2023年06月25日 09:57:36   作者:讀心悅  
tostring 和 valueOf 函數(shù)是解決值的顯示和運算的問題,本文主要介紹了js中toString()與valueOf()的使用,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

tostring 和 valueOf 函數(shù)是解決值的顯示和運算的問題。所有的 Object 類型的數(shù)據(jù)都自帶 toString 和 valueOf 函數(shù)。

比如我們定一個 Object 類型數(shù)據(jù):

const obj = {
    name: "duxin"
}
console.log(obj.valueOf()); // { name: 'duxin' }

toString()

toString 函數(shù)的作用是把一個邏輯轉(zhuǎn)換為字符串,并且返回 Object 類型數(shù)據(jù)的 toString()默認(rèn)的返回值"[object Object]"。

如果我們在定義對象的時候,可以重寫 tosString 函數(shù),這樣 toString 的返回值可讀性會更好一些,比如:

const obj = {
    name: "duxin",
    toString:function(){
        return this.name;
    }
}
console.log(obj.valueOf()); // { name: 'duxin' }
console.log(obj.toString()); // duxin

以下這些函數(shù)都是有自定義的 toString 函數(shù):

  • Array 的 toString 函數(shù)返回值是以逗號分隔的字符串;
  • Function 的 toString 函數(shù)返回值是函數(shù)自身的文本定義;
  • Date 的 toString 函數(shù)返回值是時間字符串;

在JavaScript中,Object,Array,F(xiàn)unction,Date等類型都實現(xiàn)了自定義的toString()函數(shù)。

  • Object 類型數(shù)據(jù)的 toString() 函數(shù)默認(rèn)的返回結(jié)果是 “[object Object]”,當(dāng)我們自定義新的類時,可以重寫 toString() 函數(shù),返回可讀性更高的結(jié)果。
  • Array 的 toString() 函數(shù)返回值為以逗號分隔構(gòu)成的數(shù)組成員字符串。數(shù)組也是對象,那么為什么數(shù)組返回的是對應(yīng)的字符串而不是對象,其實數(shù)組覆蓋了Object.toString方法,然后將連接數(shù)組并返回一個字符串,其中包含用逗號分隔的每個數(shù)組元素(相當(dāng)于Array.join())
  • Function 的 toString() 函數(shù)返回值為函數(shù)的文本定義
  • Date 的 toString() 函數(shù)返回值為具有可讀性的時間字符串

valueOf()

valueOf 函數(shù)返回引用類型的原始值,如果沒有原始值,就返回"{}",就是空對象的字面量。

  • Array的valueOf函數(shù)返回的值數(shù)組本身;
  • Function的valueOf函數(shù)返回的是函數(shù)本身;
  • Date的valueOf函數(shù)返回的值時間戳。

在發(fā)生數(shù)據(jù)類型轉(zhuǎn)換的時候,有l(wèi)iang兩種場景:

引用數(shù)據(jù)類型轉(zhuǎn)為String,先是調(diào)用toString函數(shù),有值的話,就直接返回該字符串;如果對象沒有toString,那就調(diào)用valueOf函數(shù),然后將原始值轉(zhuǎn)為字符串并且返回;如果toString或者valueOf都不能獲取原始值,那就拋出類型轉(zhuǎn)換異常;

var arr = [];
arr.toString = function () {
? ? ?console.log('調(diào)用了toString()函數(shù)');
? ? ?return [];
};
arr.valueOf = function () {
? ? ?console.log('調(diào)用了valueOf()函數(shù)');
? ? ?return [];
};
console.log(String(arr));

在執(zhí)行String(arr)的時候,是先將數(shù)組轉(zhuǎn)為字符串,調(diào)用的是toString,它的結(jié)果不能轉(zhuǎn)為string;

那就調(diào)用valueOf函數(shù),它的返回值也是一個空數(shù)組,也不能轉(zhuǎn)為字符串,那就只能拋出類型轉(zhuǎn)換異常了。

引用類型在轉(zhuǎn)化為number的時候,首先會判斷對象是否含有valueOf函數(shù),如果有,那就調(diào)用valueOf函數(shù),把它的返回值轉(zhuǎn)為數(shù)字,然后返回;如果沒有valueOf函數(shù),就調(diào)用toString函數(shù),將返回值轉(zhuǎn)為數(shù)字并返回。如果toString或者valueOf都不能獲取到原始值的話,那就拋出類型轉(zhuǎn)換異常。

  • Object 類型數(shù)據(jù)的valueOf()函數(shù)默認(rèn)的返回結(jié)果是"{}",即一個空的對象字面量。
  • Array 的valueOf()函數(shù)返回的是數(shù)組本身
  • function 的valueOf()函數(shù)返回的是函數(shù)本身
  • Date 的valueOf()函數(shù)返回的是指定日期的時間戳

小結(jié):

  • toString() 返回的是字符串,而 valueOf() 返回的是原始值,沒有原始值返回對象本身
  • undefined 和 null 都沒有 toString() 和 valueOf() 方法
  • Date 類型的 toString() 返回的表示時間的字符串;valueOf() 返回的是現(xiàn)在到1970年1月1日的毫秒數(shù)(時間戳)
  • Number 類型的 toString() 方法可以接收轉(zhuǎn)換基數(shù),返回不同進(jìn)制的字符串形式的數(shù)值;而 valueOf()方 法無法接受轉(zhuǎn)換基數(shù)

特殊情況

如果一個引用類型的值既存在 toString() 函數(shù)又存在 valueOf() 函數(shù),那么在做隱式轉(zhuǎn)換時,會調(diào)用哪個函數(shù)呢?這里我們可以概括成兩種場景,分別是引用類型轉(zhuǎn)換為 String 類型,以及引用類型轉(zhuǎn)換為 Number 類型。

1、引用類型轉(zhuǎn)換為 String 類型

一個引用類型的數(shù)據(jù)在轉(zhuǎn)換為 String 類型時,一般是用于數(shù)據(jù)展示,轉(zhuǎn)換時遵循以下規(guī)則:

如果對象具有 toString() 函數(shù),則會優(yōu)先調(diào)用 toString() 函數(shù)。如果它返回的是一個原始值,則會直接將這個原始值轉(zhuǎn)換為字符串表示,并返回該字符串。
反之,則會再去調(diào)用 valueOf() 函數(shù),如果 valueOf() 函數(shù)返回的結(jié)果是一個原始值,則會將這個結(jié)果轉(zhuǎn)換為字符串表示,并返回該字符串。
如果通過 toString() 函數(shù)或者 valueOf() 函數(shù)都無法獲得一個原始值,則會直接拋出類型轉(zhuǎn)換異常。

2、引用類型轉(zhuǎn)換為 Number 類型

一個引用類型的數(shù)據(jù)在轉(zhuǎn)換為 Number 類型時,一般是用于數(shù)據(jù)運算,轉(zhuǎn)換時遵循以下規(guī)則:

如果對象具有 valueOf() 函數(shù),則會優(yōu)先調(diào)用 valueOf() 函數(shù),如果 valueOf() 函數(shù)返回一個原始值,則會直接將這個原始值轉(zhuǎn)換為數(shù)字表示,并返回該數(shù)字。
反之,則會再去調(diào)用 toString() 函數(shù),如果 toString() 函數(shù)返回的結(jié)果是一個原始值,則會將這個結(jié)果轉(zhuǎn)換為數(shù)字表示,并返回該數(shù)字。
如果通過 toString() 函數(shù)或者 valueOf() 函數(shù)都無法獲得一個原始值,則會直接拋出類型轉(zhuǎn)換異常。

到此這篇關(guān)于js中toString()與valueOf()的使用的文章就介紹到這了,更多相關(guān)js toString() valueOf()內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JavaScript中實現(xiàn)無縫滾動、分享到側(cè)邊欄實例代碼

    JavaScript中實現(xiàn)無縫滾動、分享到側(cè)邊欄實例代碼

    本文給通過js代碼實現(xiàn)無縫滾動,側(cè)邊欄效果,在項目中經(jīng)常會遇到,下面小編把代碼整理分享到腳本之家平臺,供大家參考
    2016-04-04
  • JavaScript省市級聯(lián)下拉菜單實例

    JavaScript省市級聯(lián)下拉菜單實例

    這篇文章主要為大家詳細(xì)介紹了JavaScript省市級聯(lián)下拉菜單實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • js中的string.format函數(shù)代碼

    js中的string.format函數(shù)代碼

    js中的string.format函數(shù)代碼,學(xué)習(xí)js的朋友可以參考下。
    2011-07-07
  • js命名空間寫法示例

    js命名空間寫法示例

    這篇文章主要介紹了js命名空間寫法,以完整實例形式分析了JavaScript命名空間的寫法,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-12-12
  • Javascript 調(diào)試?yán)?Firebug使用詳解六

    Javascript 調(diào)試?yán)?Firebug使用詳解六

    有時候,為了更清楚方便的查看輸出信息,我們可能需要將一些調(diào)試信息進(jìn)行分組輸出,那么可以使用console.group來對信息進(jìn)行分組,在組信息輸出完成后用console.groupEnd結(jié)束分組。
    2009-07-07
  • JS合并兩個數(shù)組的3種方法詳解

    JS合并兩個數(shù)組的3種方法詳解

    這篇文章主要介紹了JS合并兩個數(shù)組的3種方法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • JavaScript數(shù)組去重和扁平化函數(shù)介紹

    JavaScript數(shù)組去重和扁平化函數(shù)介紹

    這篇文章主要介紹了JavaScript數(shù)組去重和扁平化函數(shù),數(shù)組扁平化又稱數(shù)組降維,下面文章圍繞數(shù)組去重和扁平化函數(shù)得相關(guān)資料展開內(nèi)容,需要的朋友可以參考一下
    2021-12-12
  • JavaScript 垃圾回收機(jī)制分析

    JavaScript 垃圾回收機(jī)制分析

    同C# 、Java一樣我們可以手工調(diào)用垃圾回收程序,但是由于其消耗大量資源,而且我們手工調(diào)用的不會比瀏覽器判斷的準(zhǔn)確,所以不推薦手工調(diào)用垃圾回收
    2013-10-10
  • js控制fieldset高度的代碼

    js控制fieldset高度的代碼

    js控制fieldset高度的代碼...
    2007-11-11
  • JavaScript?Promise執(zhí)行流程深刻理解

    JavaScript?Promise執(zhí)行流程深刻理解

    這篇文章主要介紹了JavaScript?Promise執(zhí)行流程深刻理解,他是一個構(gòu)造函數(shù),每個創(chuàng)建的promise都有各自狀態(tài)和值,且狀態(tài)初始值為pending,值為undefined
    2022-06-06

最新評論