欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

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

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

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

toString()

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

如果我們?cè)诙x對(duì)象的時(shí)候,可以重寫 tosString 函數(shù),這樣 toString 的返回值可讀性會(huì)更好一些,比如:

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ù)返回值是以逗號(hào)分隔的字符串;
  • Function 的 toString 函數(shù)返回值是函數(shù)自身的文本定義;
  • Date 的 toString 函數(shù)返回值是時(shí)間字符串;

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

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

valueOf()

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

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

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

引用數(shù)據(jù)類型轉(zhuǎn)為String,先是調(diào)用toString函數(shù),有值的話,就直接返回該字符串;如果對(duì)象沒有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í)候,是先將數(shù)組轉(zhuǎn)為字符串,調(diào)用的是toString,它的結(jié)果不能轉(zhuǎn)為string;

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

引用類型在轉(zhuǎn)化為number的時(shí)候,首先會(huì)判斷對(duì)象是否含有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é)果是"{}",即一個(gè)空的對(duì)象字面量。
  • Array 的valueOf()函數(shù)返回的是數(shù)組本身
  • function 的valueOf()函數(shù)返回的是函數(shù)本身
  • Date 的valueOf()函數(shù)返回的是指定日期的時(shí)間戳

小結(jié):

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

特殊情況

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

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

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

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

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

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

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

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

相關(guān)文章

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

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

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

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

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

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

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

    js命名空間寫法示例

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

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

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

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

    這篇文章主要介紹了JS合并兩個(gè)數(shù)組的3種方法詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    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)用的不會(huì)比瀏覽器判斷的準(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è)構(gòu)造函數(shù),每個(gè)創(chuàng)建的promise都有各自狀態(tài)和值,且狀態(tài)初始值為pending,值為undefined
    2022-06-06

最新評(píng)論