浅谈String.valueOf()方法的使用

关于类型转换,对象常见的两个方法是toString()和valueOf()。实际上,这两个方法也可以应用在包装类型上。前面已经介绍过toString()方法,本文将介绍valueOf()方法,该方法返回原值

【1】undefined和null没有valueOf()方法

?
1
2
undefined.valueOf(); //错误
null .valueOf(); //错误

【2】布尔型数据true和false返回原值

?
1
2
3
4
5
6
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
2
3
4
5
'1' .valueOf(); //'1'
'' .valueOf(); //''
'abc' .valueOf(); //'abc'
String.valueOf(); //String() { [native code] }
typeof String.valueOf(); //'function'

【4】数值类型分为整数和浮点数进行处理

?
1
2
Number.valueOf(); //Number() { [native code] }
typeof Number.valueOf(); //'function'

1、整数直接跟上.valueOf()形式,会报错,提示无效标记,所以尽量加括号

?
1
2
3
4
5
6
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、浮点数原值返回

?
1
2
3
4
5
6
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()不可以接收转换基数

【5】对象Object类型及自定义对象类型返回原对象

?
1
2
3
4
5
6
{}.valueOf(); //报错,Unexpected token .
({}).valueOf(); //Object{}
typeof ({}).valueOf(); //'object'
({a:123}).valueOf(); //Object{a:123}
Object.valueOf(); //Object() { [native code] }
typeof Object.valueOf(); //'function'
?
1
2
3
4
5
function Person(){
   this .name = 'test' ;
}
var person1 = new Person();
person1.valueOf(); //Person {name: "test"}

【6】函数Function类型返回原函数

?
1
2
3
4
5
6
7
function test(){
   alert(1); //test
}
test.valueOf(); /*function test(){
           alert(1);//test
          }*/
Function.valueOf(); //Function() { [native code] }

【7】数组Array类型返回原数组

?
1
2
3
4
[].valueOf(); //[]
[1].valueOf(); //[1]
[1,2,3,4].valueOf(); //[1,2,3,4]
Array.valueOf(); //Array() { [native code] }

【8】和其他对象不同,时间Date类型返回一个数字值,它是this时间值

?
1
2
3
4
Date.now(); //1465115123742
( new Date()).valueOf(); //1465115123742
typeof ( new Date()).valueOf(); //'number'
Date.valueOf(); //Date() { [native code] }

【9】正则表达式RegExp类型返回原正则对象

?
1
2
3
/ab/i.valueOf(); ///ab/i
/mom( and dad( and baby)?)?/gi.valueOf(); //mom( and dad( and baby)?)?/gi
RegExp.valueOf(); //RegExp() { [native code] }

【10】错误Error类型

?
1
2
3
4
5
6
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] }

总 结  

1、toString()和valueOf()的主要不同点在于,toString()返回的是字符串,而valueOf()返回的是原对象

2、由于undefined和null不是对象,所以它们toString()和valueOf()两个方法都没有

3、数值Number类型的toString()方法可以接收转换基数,返回不同进制的字符串形式的数值;而valueOf()方法无法接受转换基数

4、时间Date类型的toString()方法返回的表示时间的字符串表示;而valueOf()方法返回的是现在到1970年1月1日00:00:00的数值类型的毫秒数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值