淺談String.valueOf()方法的使用
前面的話
關(guān)于類型轉(zhuǎn)換,對(duì)象常見(jiàn)的兩個(gè)方法是toString()和valueOf()。實(shí)際上,這兩個(gè)方法也可以應(yīng)用在包裝類型上。前面已經(jīng)介紹過(guò)toString()方法,本文將介紹valueOf()方法,該方法返回原值
【1】undefined和null沒(méi)有valueOf()方法
undefined.valueOf();//錯(cuò)誤 null.valueOf();//錯(cuò)誤
【2】布爾型數(shù)據(jù)true和false返回原值
true.valueOf();//true typeof true.valueOf();//'boolean' false.valueOf();//false typeof false.valueOf();//'boolean' Boolean.valueOf();//Boolean() { [native code] } typeof Boolean.valueOf();//'function'
【3】字符串類型原值返回
'1'.valueOf();//'1' ''.valueOf();//'' 'abc'.valueOf();//'abc' String.valueOf();//String() { [native code] } typeof String.valueOf();//'function'
【4】數(shù)值類型分為整數(shù)和浮點(diǎn)數(shù)進(jìn)行處理
Number.valueOf();//Number() { [native code] } typeof Number.valueOf();//'function'
1、整數(shù)直接跟上.valueOf()形式,會(huì)報(bào)錯(cuò),提示無(wú)效標(biāo)記,所以盡量加括號(hào)
0.valueOf();//Uncaught SyntaxError: Invalid or unexpected token (0).valueOf();//0 +0.valueOf();//Uncaught SyntaxError: Invalid or unexpected token (+0).valueOf();//0 -0.valueOf();//Uncaught SyntaxError: Invalid or unexpected token (-0).valueOf();//-0
[注意]-0的valueOf()值是-0,而-0的toString()值是'0'
2、浮點(diǎn)數(shù)原值返回
1.23.valueOf();//1.23 +1.23.valueOf();//1.23 -1.23.valueOf();//-1.23 NaN.valueOf();//NaN Infinity.valueOf();//Infinity -Infinity.valueOf();//-Infinity
[注意]和toString()不同的是,valueOf()不可以接收轉(zhuǎn)換基數(shù)
【5】對(duì)象Object類型及自定義對(duì)象類型返回原對(duì)象
{}.valueOf();//報(bào)錯(cuò),Unexpected token . ({}).valueOf();//Object{} typeof ({}).valueOf();//'object' ({a:123}).valueOf();//Object{a:123} Object.valueOf();//Object() { [native code] } typeof Object.valueOf();//'function'
function Person(){ this.name = 'test'; } var person1 = new Person(); person1.valueOf();//Person {name: "test"}
【6】函數(shù)Function類型返回原函數(shù)
function test(){ alert(1);//test } test.valueOf();/*function test(){ alert(1);//test }*/ Function.valueOf();//Function() { [native code] }
【7】數(shù)組Array類型返回原數(shù)組
[].valueOf();//[] [1].valueOf();//[1] [1,2,3,4].valueOf();//[1,2,3,4] Array.valueOf();//Array() { [native code] }
【8】和其他對(duì)象不同,時(shí)間Date類型返回一個(gè)數(shù)字值,它是this時(shí)間值
Date.now();//1465115123742 (new Date()).valueOf();//1465115123742 typeof (new Date()).valueOf();//'number' Date.valueOf();//Date() { [native code] }
【9】正則表達(dá)式RegExp類型返回原正則對(duì)象
/ab/i.valueOf();///ab/i /mom( and dad( and baby)?)?/gi.valueOf();//mom( and dad( and baby)?)?/gi RegExp.valueOf();//RegExp() { [native code] }
【10】錯(cuò)誤Error類型
Error.valueOf();//Error() { [native code] } RangeError.valueOf();//RangeError() { [native code] } ReferenceError.valueOf();//ReferenceError() { [native code] } SyntaxError.valueOf();//SyntaxError() { [native code] } TypeError.valueOf();//TypeError() { [native code] } URIError.valueOf();//URIError() { [native code] }
總 結(jié)
1、toString()和valueOf()的主要不同點(diǎn)在于,toString()返回的是字符串,而valueOf()返回的是原對(duì)象
2、由于undefined和null不是對(duì)象,所以它們toString()和valueOf()兩個(gè)方法都沒(méi)有
3、數(shù)值Number類型的toString()方法可以接收轉(zhuǎn)換基數(shù),返回不同進(jìn)制的字符串形式的數(shù)值;而valueOf()方法無(wú)法接受轉(zhuǎn)換基數(shù)
4、時(shí)間Date類型的toString()方法返回的表示時(shí)間的字符串表示;而valueOf()方法返回的是現(xiàn)在到1970年1月1日00:00:00的數(shù)值類型的毫秒數(shù)
以上這篇淺談String.valueOf()方法的使用就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript 學(xué)習(xí)筆記之語(yǔ)句
這篇文章主要介紹了JavaScript中的語(yǔ)句,包括條件分支語(yǔ)句、循環(huán)語(yǔ)句、迭代語(yǔ)句、Lable語(yǔ)句、break和continue語(yǔ)句、with語(yǔ)句、swith語(yǔ)句,十分全面細(xì)致,推薦給小伙伴們。2015-01-01關(guān)于可運(yùn)行代碼無(wú)法正常執(zhí)行的使用說(shuō)明
腳本之家網(wǎng)站為了方便大家快速的查看效果,只要大家運(yùn)行一下代碼即可能看到效果。2010-05-05如何讓頁(yè)面在打開(kāi)時(shí)自動(dòng)刷新一次讓圖片全部顯示
我的網(wǎng)頁(yè)的圖片較多,而服務(wù)器也不是很好,所以每次打開(kāi)網(wǎng)頁(yè)后總有一、兩幅圖片無(wú)法顯示,但刷新一遍后又全部可顯示了,這種問(wèn)題相信每個(gè)人都遇到過(guò),接下來(lái)介紹詳細(xì)解決方法2012-12-12從零學(xué)JSON之JSON數(shù)據(jù)結(jié)構(gòu)
這篇文章主要介紹了JSON數(shù)據(jù)結(jié)構(gòu)的相關(guān)知識(shí),需要的朋友可以參考下2014-05-05說(shuō)說(shuō)掌握J(rèn)avaScript語(yǔ)言的思想前提想學(xué)習(xí)js的朋友可以看看
無(wú)論是公司的同事還是外界的程序員朋友們,大部分人對(duì)JavaScript的高級(jí)應(yīng)用不甚了解,已有的知識(shí)架構(gòu)里會(huì)認(rèn)為JavaScript僅僅是一門腳本語(yǔ)言,其作用是給頁(yè)面做一些錦上添花的效果,比如表單驗(yàn)證等等。2009-04-04