您的位置:首页 > Web前端 > JavaScript

JS数据类型转换

2017-11-23 23:42 537 查看
JavaScript 是一种动态类型语言,变量没有类型限制,可以随时赋予任意值。

1、强制转换

强制转换主要指使用Number、String和Boolean三个构造函数,手动将各种类型的值,转换成数字、字符串或者布尔值。

Number()

Number(1)
1
Number('123')
123
Number('hello world')
NaN
Number(true)
1
Number(false)
0
Number(null)
0
Number(undefined)
NaN
Number([1,2,3])
NaN
Number([3])
3
Number(function(){})
NaN
Number({})
NaN


ECMAScript 提供了两种把非数字的原始值转换成数字的方法,即 parseInt() 和 parseFloat()。

parseInt('123abc')
123
parseInt('abc123')
NaN
parseFloat('abc123.123')
NaN
parseFloat('123.123qwe')
123.123


上面代码中,parseInt逐个解析字符,而Number函数整体转换字符串的类型。Number函数将字符串转为数值,要比parseInt函数严格很多。基本上,只要有一个字符无法转成数值,整个字符串就会被转为NaN。

Number() 原理如下:

var obj = {
valueOf: function () {
return {};
},
toString: function () {
return {};
}
};

Number(obj)


报错:Cannot convert object to primitive value(…)

var obj = {
valueOf: function () {
return [];
},
toString: function () {
return 3;
}
};

Number(obj)
3


var obj = {
valueOf: function () {
return 5;
},
toString: function () {
return 3;
}
};

Number(obj)
5


比较上面代码结果可看出:Number()方法实际是先调用对象自身的valueOf(),如果返回的结果不是原始类型值,则再调用自身的toString()方法。

String()

String('111')
"111"
String(222)
"222"
String(true)
"true"
String('false')
"false"
String(undefined)
"undefined"
String(null)
"null"
String('')
""
String([])
""
String([1,2,3])
"1,2,3"
String({x:1, y:2})
"[object Object]"
String(function(){})
"function (){}"


String方法背后的转换规则,与Number方法基本相同,只是互换了valueOf方法和toString方法的执行顺序。

Boolean()

使用Boolean函数,可以将任意类型的变量转为布尔值

Boolean(1)
true
Boolean(0)
false
Boolean('')
false
Boolean('123')
true
Boolean(null)
false
Boolean(undefined)
false
Boolean([])
true
Boolean({})
true
Boolean(NaN)
false


它的转换规则相对简单:除了以下六个值的转换结果为false,其他的值全部为true。

undefined

null

-0

0或+0

NaN

”(空字符串)

2. 自动转换(隐式转换)

if('abc'){console.log(1)}
1


if(1+'1'){console.log(1+'1')}
11
4000


除了加法运算符有可能把运算子转为字符串,其他运算符都会把运算子自动转成数值。注意:null 转为数值时为0,而 undefined 转为数值时为 NaN。

"1"-1
0
"undefined"-1
NaN
null-0
0
null-1
-1
true-1
0
false-0
0
"1"*1
1
"2"/2
1
"2"%1
0
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  javascript