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

JavaScript中valueOf函數(shù)與toString方法深入理解

 更新時間:2012年12月02日 10:26:41   作者:  
基本上,所有JS數(shù)據(jù)類型都擁有valueOf和toString這兩個方法,null除外。它們倆解決javascript值運算與顯示的問題,本文將詳細介紹,有需要的朋友可以參考下
JavaScript中valueOf函數(shù)方法是返回指定對象的原始值。使用方法:
object.valueOf( )object是必選項參數(shù)是任意固有 JScript 對象。
每個JavaScript固有對象的 valueOf 方法定義不同。
對象 返回值
Array 數(shù)組的元素被轉(zhuǎn)換為字符串,這些字符串由逗號分隔,連接在一起。其操作與 Array.toString 和 Array.join 方法相同。
Boolean Boolean 值。
Date 存儲的時間是從 1970 年 1 月 1 日午夜開始計的毫秒數(shù) UTC。
Function 函數(shù)本身。
Number 數(shù)字值。
Object 對象本身。這是默認情況。
String 字符串值。

Math 和 Error 對象沒有 valueOf 方法。

基本上,所有JS數(shù)據(jù)類型都擁有valueOf和toString這兩個方法,null除外。它們倆解決javascript值運算與顯示的問題。
JavaScript 的 valueOf() 方法
valueOf() 方法可返回 Boolean 對象的原始值。
用法booleanObject.valueOf(),返回值為booleanObject 的原始布爾值。如果調(diào)用該方法的對象不是 Boolean,則拋出異常 TypeError。
復(fù)制代碼 代碼如下:

<script type="text/javascript">
var boo = new Boolean(false);
document.write(boo.valueOf());
</script>

以上腳本會輸出false。
JavaScript 的 toString() 方法
toString() 方法可把一個邏輯值轉(zhuǎn)換為字符串,并返回結(jié)果。
用法 booleanObject.toString(),返回值根據(jù)原始布爾值或者 booleanObject 對象的值返回字符串 "true" 或 "false"。如果調(diào)用該方法的對象不是 Boolean,則拋出異常 TypeError。
在 Boolean 對象被用于字符串環(huán)境中時,此方法會被自動調(diào)用。
下面腳本將創(chuàng)建一個 Boolean 對象,并把它轉(zhuǎn)換成字符串:
復(fù)制代碼 代碼如下:

<script type="text/javascript">
var boo = new Boolean(true);
document.write(boo.toString());
</script>

腳本輸出:true。
先看一例
復(fù)制代碼 代碼如下:

var aaa = {
i: 10,
valueOf: function() { return this.i+30; },
toString: function() { return this.valueOf()+10; }
}
alert(aaa > 20); // true
alert(+aaa); // 40
alert(aaa); // 50

之所以有這樣的結(jié)果,因為它們偷偷地調(diào)用valueOf或toString方法。但如何區(qū)分什么情況下是調(diào)用了哪個方法呢,我們可以通過另一個方法測試一下。由于用到console.log,請在裝有firebug的FF中實驗!
復(fù)制代碼 代碼如下:

var bbb = {
i: 10,
toString: function() {
console.log('toString');
return this.i;
},
valueOf: function() {
console.log('valueOf');
return this.i;
}
}
alert(bbb);// 10 toString
alert(+bbb); // 10 valueOf
alert(''+bbb); // 10 valueOf
alert(String(bbb)); // 10 toString
alert(Number(bbb)); // 10 valueOf
alert(bbb == '10'); // true valueOf
alert(bbb === '10'); // false

乍一看結(jié)果,大抵給人的感覺是,如果轉(zhuǎn)換為字符串時調(diào)用toString方法,如果是轉(zhuǎn)換為數(shù)值時則調(diào)用valueOf方法,但其中有兩個很不和諧。一個是alert(''+bbb),字符串合拼應(yīng)該是調(diào)用toString方法……另一個我們暫時可以理解為===操作符不進行隱式轉(zhuǎn)換,因此不調(diào)用它們。為了追究真相,我們需要更嚴謹?shù)膶嶒灐?
復(fù)制代碼 代碼如下:

var aa = {
i: 10,
toString: function() {
console.log('toString');
return this.i;
}
}
alert(aa);// 10 toString
alert(+aa); // 10 toString
alert(''+aa); // 10 toString
alert(String(aa)); // 10 toString
alert(Number(aa)); // 10 toString
alert(aa == '10'); // true toString
再看valueOf。
var bb = {
i: 10,
valueOf: function() {
console.log('valueOf');
return this.i;
}
}
alert(bb);// [object Object]
alert(+bb); // 10 valueOf
alert(''+bb); // 10 valueOf
alert(String(bb)); // [object Object]
alert(Number(bb)); // 10 valueOf
alert(bb == '10'); // true valueOf
發(fā)現(xiàn)有點不同吧?!它沒有像上面toString那樣統(tǒng)一規(guī)整。對于那個[object Object],我估計是從Object那里繼承過來的,我們再去掉它看看。
Object.prototype.toString = null;
var cc = {
i: 10,
valueOf: function() {
console.log('valueOf');
return this.i;
}
}
alert(cc);// 10 valueOf
alert(+cc); // 10 valueOf
alert(''+cc); // 10 valueOf
alert(String(cc)); // 10 valueOf
alert(Number(cc)); // 10 valueOf
alert(cc == '10'); // true valueOf

如果只重寫了toString,對象轉(zhuǎn)換時會無視valueOf的存在來進行轉(zhuǎn)換。但是,如果只重寫了valueOf方法,在要轉(zhuǎn)換為字符串的時候會優(yōu)先考慮valueOf方法。在不能調(diào)用toString的情況下,只能讓valueOf上陣了。對于那個奇怪的字符串拼接問題,可能是出于操作符上,翻開ECMA262-5 發(fā)現(xiàn)都有一個getValue操作。嗯,那么謎底應(yīng)該是揭開了。重寫會加大它們調(diào)用的優(yōu)化高,而在有操作符的情況下,valueOf的優(yōu)先級本來就比toString的高。

相關(guān)文章

  • JavaScript的11個小技巧整理

    JavaScript的11個小技巧整理

    這篇文章介紹了JavaScript的11個小技巧,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • javascript之Partial Application學(xué)習(xí)

    javascript之Partial Application學(xué)習(xí)

    在數(shù)學(xué)中,一個函數(shù)是描述每個輸入值對應(yīng)唯一輸出值的這種對應(yīng)關(guān)系,符號為 f(x)。例如,表達式 f(x)=x2表示了一個函數(shù) f,其中每個輸入值x都與唯一輸出值x2相聯(lián)系
    2013-01-01
  • JS/HTML5游戲常用算法之路徑搜索算法 隨機迷宮算法詳解【普里姆算法】

    JS/HTML5游戲常用算法之路徑搜索算法 隨機迷宮算法詳解【普里姆算法】

    這篇文章主要介紹了JS/HTML5游戲常用算法之路徑搜索算法 隨機迷宮算法,結(jié)合實例形式詳細分析了針對迷宮游戲路徑搜索算法的普里姆算法相關(guān)原理、實現(xiàn)方法及操作注意事項,需要的朋友可以參考下
    2018-12-12
  • JavaScript事件

    JavaScript事件 "事件對象"的注意要點

    這篇文章主要介紹了JavaScript事件,告訴大家"事件對象"的注意要點,感興趣的小伙伴們可以參考一下
    2016-01-01
  • 微信小程序報錯:does?not?have?a?method?"xxxx"?to?handle?event?"tap"的解決方案

    微信小程序報錯:does?not?have?a?method?"xxxx"?to?ha

    這篇文章主要給大家介紹了關(guān)于微信小程序報錯:does?not?have?a?method?"xxxx"?to?handle?event?"tap"的解決方案,文中將解決的辦法介紹的非常詳細,需要的朋友可以參考下
    2023-01-01
  • 微信小程序分包的超詳細步驟

    微信小程序分包的超詳細步驟

    分包指的是把一個完整的小程序項目,按照需求劃分為不同的子包,在構(gòu)建時打包成不同的分包,用戶在使用時按需進行加載,下面這篇文章主要給大家介紹了關(guān)于微信小程序分包的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • JS獲取瀏覽器語言動態(tài)加載JS文件示例代碼

    JS獲取瀏覽器語言動態(tài)加載JS文件示例代碼

    通過獲取瀏覽器語言版本,來相對的加載easyui語言包就是動態(tài)加載JS文件,下面有個不錯的實例,大家可以看看
    2014-10-10
  • 禁用backspace網(wǎng)頁回退功能的實現(xiàn)代碼

    禁用backspace網(wǎng)頁回退功能的實現(xiàn)代碼

    下面小編就為大家?guī)硪黄胋ackspace網(wǎng)頁回退功能的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • 原生JS實現(xiàn)飛機大戰(zhàn)小游戲

    原生JS實現(xiàn)飛機大戰(zhàn)小游戲

    這篇文章主要為大家詳細介紹了原生JS實現(xiàn)飛機大戰(zhàn)小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • Bootstrap開發(fā)實戰(zhàn)之響應(yīng)式輪播圖

    Bootstrap開發(fā)實戰(zhàn)之響應(yīng)式輪播圖

    這篇文章主要為大家詳細介紹了Bootstrap開發(fā)實戰(zhàn)之響應(yīng)式輪播圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-06-06

最新評論