js中的数据类型和数据类型转换

本文深入讲解JavaScript中的数据类型,包括原始类型与对象类型,并详细解释了显式类型转换与隐式类型转换的过程及应用场景。

js中的数据类型

原始类型 String Number Boolean Null Undefined Symbol

对象 Object

显式类型转换

显示类型转换是通过调用下面这三个函数来进行的。

  • Number( )
  • String( )
  • Boolean( )
1. Number( )

数值: 转换之后还是数值
字符串: 如果可以被解析为数值,则转为数值,否则转为NaN,空字符串转为0
布尔值: true转成1, false转为0
undefined: 转成NaN
null : 转成0
对象: 这个稍微复杂一些,具体的过程如下

  • 1.如果调用对象本身的valueOf方法返回的是原始数据类型,则调用Number()来对返回的值进行处理。
  • 2.如果调用对象本身的valueOf方法之后返回的复合数据类型,则调用对象自身的toString方法,如果toString的返回值是原始的数据类型,则对该值使用Number()处理,不再进行后续步骤。如果toString返回的是复合的数据类型,则报错。

https://codepen.io/zhaojianxi...

2. String( )

数值: 转换成对应的字符串
字符串: 还是自身
布尔值 : true转为‘true’ ,false转为‘false’
undefined: 转为“undefined”
null : 转为 ‘null’
对象:这个过程一样是有点复杂,具体的过程如下

  1. 如果调用对象本身的toString方法返回的是原始数据类型,则调用String()来, 不再进行以下步骤。
  2. 如果toString方法返回的是复合类型的值,再调用valueOf方法,如果ValueOf返回的是原始类型的值,则对该值使用String方法,如果valueOf方法返回的是复合类型的值,则报错。

https://codepen.io/zhaojianxi...

3. Boolean()

除undefined,null,0,NaN,空字符串之外,全部返回true。

隐式类型转换

隐式类型转换的场景大概有如下几种

  1. 四则运算
  2. 判断语句
  3. native调用

https://github.com/JesseZhao1...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值