自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JavaScript中valueOf、toString的隱式調(diào)用

開發(fā) 前端
今天在群上有人問這樣一個問題

今天在群上有人問這樣一個問題:

函數(shù)add可以實現(xiàn)連續(xù)的加法運(yùn)算
函數(shù)add語法如下
add(num1)(num2)(num3)...;//注意這里是省略號喲,***
使用舉例如下:
add(10)(10)=20;
add(10)(20)(50)=80;
add(10)(20)(50)(100)=180;
請用js代碼實現(xiàn)函數(shù)add。

自個琢磨了一會只能Google之,代碼如下:

  1. function add(num){ 
  2.         var sum=num, 
  3.          
  4.             tmp=function(v){ 
  5.                 sum+=v; 
  6.                 return tmp 
  7.             }; 
  8.          
  9.         tmp.toString=function(){ 
  10.             return sum 
  11.         }; 
  12.          
  13.         return tmp 
  14.     } 
  15.      
  16.      
  17.     alert( add(10)(20)(50) )        //80 

起初沒弄懂為什么會返回80,因為toString方法一直沒被調(diào)用啊,怎么會返回sum呢;后來知道原來toString被隱式調(diào)用了,也就有了下文。

先引用一段話

 

每個對象的toString和valueOf方法都可以被改寫,每個對象執(zhí)行完畢,如果被用以操作JavaScript解析器就會自動調(diào)用對象的toString或者valueOf方法,舉栗子:

 

  1. //我們先創(chuàng)建一個對象,并修改其toString和valueOf方法 
  2.     var obj={ 
  3.          
  4.         i:10, 
  5.          
  6.         valueOf:function(){ 
  7.              
  8.             console.log('執(zhí)行了valueOf()'); 
  9.              
  10.             return this.i+20 
  11.              
  12.         }, 
  13.          
  14.         toString:function(){ 
  15.              
  16.             console.log('執(zhí)行了toString()'); 
  17.              
  18.             return this.valueOf()+20 
  19.         } 
  20.     } 
  21.      
  22.     //當(dāng)我們調(diào)用的時候: 
  23.      
  24.     alert( obj )    //50       執(zhí)行了toString() 執(zhí)行了valueOf() 
  25.     alert( +obj )    //30       執(zhí)行了valueOf() 
  26.     alert( obj>40 )    //false       執(zhí)行了valueOf() 
  27.     alert( obj==30 )    //true       執(zhí)行了valueOf() 
  28.     alert( obj===30 )    //false 
  29.     //***這個未輸出任何字符串,個人猜想是這樣的:全等比較時,js解析器直接先判斷類型是否一樣,明顯一個是Object,一個是Number,所以直接不相等,根本不需要再去求值了。 

由上可以看出,雖然我們沒有調(diào)用obj的任何方法,但是要使用obj進(jìn)行操作時,好像(其實就是,如果我們是創(chuàng)造js解析器的人這些就不是問題了,哎)js解析器自動幫我們調(diào)用了其toString或valueOf方法。

接下來就是探究什么時候執(zhí)行的是toString方法,什么時候執(zhí)行的是valueOf方法了。大致猜這樣:如果做加減乘除、比較運(yùn)算的時候執(zhí)行的是valueOf方法,如果是需要具體值呢就執(zhí)行的是toString方法。更嚴(yán)謹(jǐn)?shù)膶嶒瀼?fù)制一下,請原諒(原文地址):

 看到這里,我們回顧一下之前我們使用 字符串和數(shù)字加減 等操作的隱式轉(zhuǎn)換:

 

  1. var age = 30; 
  2. age.toString() + 'year old'// '30 year old' 
  3. age + ' years old'// '30 years old' 

在運(yùn)行 age.toString() + 'year old'時,age變量通過調(diào)用toString函數(shù)顯式的從Number型轉(zhuǎn)換成String型。而在運(yùn)行age + ' years old'時,我們沒有顯式的調(diào)用函數(shù),age也被轉(zhuǎn)換成String型,這里就是javascript引擎做了隱式類型轉(zhuǎn)換。隱式類型轉(zhuǎn)換可以認(rèn)為 javascript引擎調(diào)用的相應(yīng)的類型轉(zhuǎn)換函數(shù)來進(jìn)行類型轉(zhuǎn)換,age + ' years old'其實等價于age.toString() + 'years old',隱式類型轉(zhuǎn)換和顯式類型轉(zhuǎn)換其實是一回事情(當(dāng)然,具體怎么優(yōu)秀的做隱式轉(zhuǎn)換的還是造js解析器的人最清楚,他怎么不告訴我們怎么造的呢... (☆▽☆)...這樣的游戲好玩么[[137874]])。
哈哈,其實就是之前沒對隱式類型轉(zhuǎn)換做深入研究,只知道,哦是這樣,隱式類型轉(zhuǎn)換嘛。所以換個上面add函數(shù)的形式就不知道是怎么回事了,不過現(xiàn)在算是弄清楚了(吧)。

參考:

http://www.cnblogs.com/rubylouvre/archive/2010/10/01/1839748.html

http://zjuwwq.gitbooks.io/jump_javascript/content/data_types/type_conversion.html

責(zé)任編輯:王雪燕 來源: 博客園
相關(guān)推薦

2023-12-05 08:18:51

函數(shù)valueOf

2010-01-07 17:42:23

Linux動態(tài)庫

2023-08-14 08:35:36

2017-09-13 10:58:51

JavaScript轉(zhuǎn)換規(guī)則

2010-11-16 15:11:52

Oracle隱式游標(biāo)

2017-09-05 16:17:35

JavaScript運(yùn)算轉(zhuǎn)換

2023-09-22 09:04:00

C++編程

2020-09-25 15:40:22

toStringvalueOf前端

2010-06-22 13:32:26

函數(shù)式編程JavaScript

2019-07-23 15:04:54

JavaScript調(diào)用棧事件循環(huán)

2023-12-12 08:50:22

MySQL隱式轉(zhuǎn)換varchar

2009-07-20 17:59:07

JavaScript調(diào)ASP.NET AJA

2009-07-21 13:54:55

Scala重載方法隱式轉(zhuǎn)換

2024-08-28 08:50:11

MySQL核心模塊

2022-02-23 21:24:21

索引SQL字符

2010-07-30 12:56:02

Flex調(diào)用JavaS

2017-07-28 09:39:12

隱式IntentAndroid M

2009-09-03 13:50:22

ToString(st

2009-04-21 09:37:50

ASP.NETAjaxJavaScript

2009-09-01 10:49:28

C#具有隱式類型聲明
點贊
收藏

51CTO技術(shù)棧公眾號