西西軟件園多重安全檢測下載網(wǎng)站、值得信賴的軟件下載站!
軟件
軟件
文章
搜索

首頁編程開發(fā)javascript|JQuery → JS中令人發(fā)指的valueOf方法

JS中令人發(fā)指的valueOf方法

相關(guān)軟件相關(guān)文章發(fā)表評論 來源:西西整理時間:2013/2/22 1:11:41字體大。A-A+

作者:chyingp點擊:150次評論:0次標簽: valueOf

  • 類型:數(shù)據(jù)庫類大小:6.5M語言:中文 評分:10.0
  • 標簽:
立即下載

彭老濕近期月報里提到了valueOf方法,興致來了翻了下ECMA5里關(guān)于valueOf方法的介紹,如下:

15.2.4.4 Object.prototype.valueOf ( )
When the valueOf method is called, the following steps are taken:
1. Let O be the result of calling ToObject passing the this value as the argument.
2. If O is the result of calling the Object constructor with a host object (15.2.2.1), then
a. Return either O or another value such as the host object originally passed to the constructor. The specific result that is returned is implementation-defined.
3. Return O.

規(guī)范里面的對于valueOf的解釋很短,大致為:調(diào)用ToObject方法(一個抽象方法,后面會講到),并將this的值作為參數(shù)傳入。

針對調(diào)用ToObject時傳入的不同參數(shù)(this),返回值分別如下:

1、this為宿主對象時,返回值取決于瀏覽器的實現(xiàn),即不同瀏覽器的返回可能不同(關(guān)于宿主對象,可參考http://www.w3school.com.cn/js/pro_js_object_types.asp)

2、this不是宿主對象,則返回ToObject(this)的值

參數(shù)類型  返回結(jié)果
Undefined拋出TypeError異常
Null拋出TypeError異常
Number創(chuàng)建一個Number對象,它內(nèi)部的初始值為傳入的參數(shù)值
String創(chuàng)建一個String對象,它內(nèi)部的初始值為傳入的參數(shù)值
Boolean創(chuàng)建一個Boolean對象,它內(nèi)部的初始值為傳入的參數(shù)值
Object返回傳入的參數(shù)(無轉(zhuǎn)換)

根據(jù)Object.prototype.valueOf的定義,以及抽象方法ToObject的描述,可得下表

obj類型  Object.prototype.valueOf.call(obj)返回結(jié)果
Undefined拋出TypeError異常
Null拋出TypeError異常
NumberNumber類型的對象,值等于obj
StringString類型的對象,值等于obj
BooleanBoolean類型的對象,值等于obj
Objectobj對象本身

舉幾個具體的例子:


var num = 123;
console.log(num.valueOf());  //輸出:123
console.log(num.valueOf());  //輸出:'number'

var unde = undefined;
console.log(Object.prototype.valueOf.call(unde));  //輸出:'TypeError: Cannot convert null to object'

var obj = {name:'casper'};
var linkObj = obj.valueOf();
linkObj.name = 'change';
console.log(linkObj.name);  //輸出:'change' ...說明obj.valueOf()返回的是對象自身



 實際上,上面沒有提到Array、Function對象,根據(jù)下面代碼可以猜想,當Object.prototype.valueOf調(diào)用時,參數(shù)為Array、Function類型的對象時,返回的結(jié)果也為對象自身:


var arr = [1, 2 ,3];
var linkArr = arr.valueOf();
linkArr[0] = ['casper'];
console.log(linkArr);  //輸出:['casper', 2, 3]

var foo = function(){ return 1; };
var linkFoo = foo.valueOf();
linkFoo.test = 'casper';
console.log(linkFoo.test);  //輸出:'casper'



看完上面的描述,是不是有種恍然大悟的感覺?如果是的話,恭喜你,可能你跟我一樣其實還沒完全理解透徹。

簡單舉個例子,當調(diào)用Object.prototype.valueOf的對象為數(shù)值類型時,假設(shè)該對象是名稱為num,num很有可能通過下面兩種方式聲明:


var num = 123;  //通過對象字面量聲明
console.log(typeof num);  //輸出:'number'

var num = new Number(123);  //通過構(gòu)造方法聲明
console.log(typeof num);  //輸出:'object'



更多變態(tài)聲明方式,可參見《一眼毀三觀:JS中不為人知的五種聲明Number的方式》

關(guān)于返回值的說明,ECMA5里面原文如下:

Create a new Number object whose [[PrimitiveValue]] internal property is set to the value of the argument. See 15.7 for a description of Number objects. 

按照這段文字的說明,似乎num.valueOf()返回的應(yīng)該是個Number對象(非字面量聲明的那種),但實際上:


var num = 123;
var tmp = num.valueOf();
console.log(typeof tmp);  //輸出: 'number'



這是怎么回事呢?于是又仔細翻看了下,似乎有些接近真相了:

5.7.4.4 Number.prototype.valueOf ( )

Returns this Number value.

The valueOf function is not generic; it throws a TypeError exception if its this value is not a Number or a Number object. Therefore, it cannot be transferred to other kinds of objects for use as a method. 

原來Number有屬于自身的原型valueOf方法,不是直接從Object.prototype上繼承下來,類似的,Boolean、String也有自己的原型valueOf方法,歸納如下:

類型    是否有屬于自己的原型valueOf方法
Undefined
Null
Number有,Number.prototype.valueOf
String有,String.prototype.valueOf
Boolean有,Boolean.prototype.valueOf
Object-

此處之外,Array、Function并沒有自己的原型valueOf方法,見規(guī)范說明:

NOTE The Array prototype object does not have a valueOf property of its own; however, it inherits the valueOf property from the standard built-in Object prototype Object. 

The Function prototype object does not have a valueOf property of its own; however, it inherits the valueOf property from the Object prototype Object. 

補充說明:Number.prototype.valueOf的內(nèi)部轉(zhuǎn)換規(guī)則比想的要略復(fù)雜些,此處不展開。

啰啰嗦嗦說了一大通,現(xiàn)在還有兩個問題存在疑惑:

關(guān)于ToObject,當參數(shù)為Function對象時,返回對象作何處理似乎沒見到規(guī)范里明確說明,當前僅靠實驗猜測(也有可能是我沒找到)

valueOf的使用場景,實際開發(fā)中尚未見到有兄弟用過

    數(shù)據(jù)庫
    (31)數(shù)據(jù)庫
    西西軟件園提供常用的數(shù)據(jù)軟件下載,數(shù)據(jù)庫軟件有很多,不過常用的就是Access,sqlserver,mysql,oracle。數(shù)據(jù)庫是一個長期存儲在計算機內(nèi)的、有組織的、有共享的、統(tǒng)一管理的數(shù)據(jù)集合。它是一個按數(shù)據(jù)結(jié)構(gòu)來存儲和管理數(shù)據(jù)的計算機軟件系統(tǒng)。...更多>>
    • PowerDesignerv15.1 漢化特別版

      05-15 / 270.6M

      推薦理由:PowerDesigner 的4 種模型文件: 概念數(shù)據(jù)模型 (CDM) CDM 表現(xiàn)數(shù)據(jù)庫的全部邏輯的結(jié)構(gòu),與任何的軟件或數(shù)據(jù)儲
    • Access 2003 中文綠色版sp3

      05-15 / 105.3M

      推薦理由:這是從office2003中提出來的access單獨組件,只包括了access。第一次解壓后先執(zhí)行一下綠化安裝.vbs然后才能
    • mysql數(shù)據(jù)庫管理工具(navicat for

      10-11 / 23.5M

      推薦理由:最新版navicatformysql,自帶注冊碼。已經(jīng)綠化,解壓到任意目錄就可運行。NavicatPremium是一個可多重連接的
    • Visual Foxpro 6.0 (VFP6.0)簡體中

      05-15 / 64.9M

      推薦理由: 現(xiàn)在很多職高學(xué)校還都是用的Visual Foxpro 6.0,盡管Visual Foxpro 6.0在10前就已經(jīng)開發(fā)出來了,現(xiàn)在都是
    • mysql圖形化界面軟件(navicat 8 fo

      05-15 / 12.1M

      推薦理由:Navicat MySQL是一套強大的MySQL資料庫伺服器管理及開發(fā)工具。它可以用于在任何3.21或以上的MySQL版本,并支
    • MS SQL 2000簡體中文4合一帶 sp4補

      10-10 / 535M

      推薦理由:這是Microsoftsqlserver2000簡體中文4in1版本DEVELOPER、ENTERPRISE、PERSONAL、STANDARD四個版本。MSSQL20

    相關(guān)評論

    閱讀本文后您有什么感想? 已有人給出評價!

    • 8 喜歡喜歡
    • 3 頂
    • 1 難過難過
    • 5 囧
    • 3 圍觀圍觀
    • 2 無聊無聊

    熱門評論

    最新評論

    發(fā)表評論 查看所有評論(0)

    昵稱:
    表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
    字數(shù): 0/500 (您的評論需要經(jīng)過審核才能顯示)