亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JS中令人發指的valueOf方法介紹

2019-11-20 22:59:21
字體:
來源:轉載
供稿:網友
彭老濕近期月報里提到了valueOf方法,興致來了翻了下ECMA5里關于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.
規范里面的對于valueOf的解釋很短,大致為:調用ToObject方法(一個抽象方法,后面會講到),并將this的值作為參數傳入。

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

1、this為宿主對象時,返回值取決于瀏覽器的實現,即不同瀏覽器的返回可能不同(關于宿主對象,可參考http://www.w3school.com.cn/js/pro_js_object_types.asp)
2、this不是宿主對象,則返回ToObject(this)的值 
參數類型  返回結果
Undefined拋出TypeError異常
Null拋出TypeError異常
Number創建一個Number對象,它內部的初始值為傳入的參數值
String創建一個String對象,它內部的初始值為傳入的參數值
Boolean創建一個Boolean對象,它內部的初始值為傳入的參數值
Object返回傳入的參數(無轉換)

根據Object.prototype.valueOf的定義,以及抽象方法ToObject的描述,可得下表 
obj類型  Object.prototype.valueOf.call(obj)返回結果
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對象,根據下面代碼可以猜想,當Object.prototype.valueOf調用時,參數為Array、Function類型的對象時,返回的結果也為對象自身:
復制代碼 代碼如下:

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'

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

簡單舉個例子,當調用Object.prototype.valueOf的對象為數值類型時,假設該對象是名稱為num,num很有可能通過下面兩種方式聲明:
復制代碼 代碼如下:

var num = 123; //通過對象字面量聲明console.log(typeof num); //輸出:'number'
var num = new Number(123); //通過構造方法聲明console.log(typeof num); //輸出:'object'

更多變態聲明方式,可參見《JS中不為人知的五種聲明Number的方式

關于返回值的說明,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()返回的應該是個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方法,見規范說明:

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的內部轉換規則比想的要略復雜些,此處不展開。

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕av一区二区三区谷原希美| 亚洲无亚洲人成网站77777| 17婷婷久久www| 欧美wwwwww| 亚洲精品在线91| 亚洲专区在线视频| 中文字幕日韩精品在线观看| 永久免费毛片在线播放不卡| 欧美日韩爱爱视频| 亚洲男人天堂网| 欧美激情一二三| 国产一区二区日韩精品欧美精品| 久久久久久91| 午夜精品理论片| 欧洲亚洲免费视频| 狠狠躁天天躁日日躁欧美| 久久久久久久久久久网站| 亚洲新声在线观看| 精品亚洲一区二区三区在线播放| 国产综合在线视频| 成人福利视频在线观看| 欧美日韩一区免费| 色综久久综合桃花网| 亚洲精品国产拍免费91在线| 国产成人久久久| 亚洲视频在线观看视频| 国产精品视频公开费视频| 欧美午夜精品久久久久久人妖| 亚洲香蕉av在线一区二区三区| 中文字幕日韩视频| 国产成人亚洲精品| 最近2019中文字幕mv免费看| 精品久久久久久久久国产字幕| 久久久精品中文字幕| 国产精品亚洲第一区| 亚洲成色777777在线观看影院| 日韩大片在线观看视频| 国产亚洲精品va在线观看| 亚洲国产高清福利视频| 久久久伊人欧美| 日韩精品免费在线视频| 91国产视频在线| 精品视频在线播放色网色视频| 亚洲精品国产综合区久久久久久久| 国产精品久久久久久久久免费| 国产精品久久久久免费a∨大胸| 91精品国产免费久久久久久| 国产精品嫩草影院久久久| 国产精品日韩电影| 久久久最新网址| 俺去了亚洲欧美日韩| 久久影院模特热| 日韩成人av在线播放| 日韩视频欧美视频| 亚洲精品国产拍免费91在线| 日本欧美中文字幕| 久久精品色欧美aⅴ一区二区| 欧美三级欧美成人高清www| 免费97视频在线精品国自产拍| 好吊成人免视频| 国产欧美亚洲视频| 色噜噜久久综合伊人一本| 97视频免费看| 久久久亚洲欧洲日产国码aⅴ| 日韩精品在线看| 日韩免费在线看| 欧美一级淫片aaaaaaa视频| 国产欧美精品xxxx另类| 亚洲激情电影中文字幕| 97视频免费看| 中文字幕亚洲色图| 91亚洲精品在线观看| 97在线免费观看视频| 亚洲成人动漫在线播放| 91色琪琪电影亚洲精品久久| 欧美精品久久久久久久| 欧美激情欧美狂野欧美精品| 亚洲人成电影在线观看天堂色| 日韩激情av在线播放| 亚洲国产精品女人久久久| 欧美国产在线电影| 98精品在线视频| 久久福利网址导航| 亚洲欧美日韩国产中文专区| 成人网在线视频| 国产精品成久久久久三级| 国产日韩中文在线| 欧美精品一区在线播放| 久久视频这里只有精品| 亚洲综合av影视| 日韩国产一区三区| 亚洲美腿欧美激情另类| 欧美精品电影免费在线观看| 国产成人精品一区二区| 欧美有码在线观看视频| 日本精品免费一区二区三区| 精品国偷自产在线| www.亚洲人.com| 成人日韩av在线| 国产视频精品xxxx| 国产精品香蕉av| www.亚洲免费视频| 国产午夜一区二区| 亚洲女人天堂成人av在线| 国自产精品手机在线观看视频| 国产精品网站视频| 久久精品视频一| 国产精品揄拍一区二区| 亚洲天堂男人的天堂| 欧美成人中文字幕| 91精品视频大全| 91最新国产视频| 国产精品电影观看| 亚洲成av人片在线观看香蕉| 日韩黄色在线免费观看| 日本a级片电影一区二区| 日韩人体视频一二区| 欧美在线视频观看免费网站| 国产精品久久久久av| 国产精品永久免费| 日本欧美精品在线| 青青a在线精品免费观看| 亚洲电影免费观看高清完整版在线| 亚洲国产欧美一区二区三区久久| 欧美日韩日本国产| 亚洲最大福利视频| 欧美一区二区视频97| 九色精品美女在线| 91精品国产综合久久久久久久久| 国产欧美精品日韩| 亚洲精品福利免费在线观看| 久久久久999| 亚洲国产中文字幕久久网| 国产精品第10页| 亚洲欧洲一区二区三区在线观看| 精品久久久久久久大神国产| 高清亚洲成在人网站天堂| 日韩欧美大尺度| 成人国产在线激情| 全色精品综合影院| 国产一区二区黑人欧美xxxx| 久久国产精品电影| 国产在线999| 久久久久久久影院| 国产自产女人91一区在线观看| 欧美激情在线视频二区| 国产成人小视频在线观看| 亚洲欧美三级伦理| 成人免费网站在线| 成人信息集中地欧美| 久久精品视频一| 一区二区三区天堂av| 欧美日韩国产一区二区| 国产不卡视频在线| 亚洲男人7777| 国产在线精品播放| 亚洲欧美日韩高清| 成人xxxx视频| 欧美日韩另类在线| 亚洲国产精品va在线观看黑人| 欧美午夜精品久久久久久久| 久久视频国产精品免费视频在线| 国产精品久久久久久久久久久久久| 成人在线观看视频网站|