JS类型转换机制

JS中有六种简单数据类型和一种引用类型。变量在声明时无固定类型,运行时确定。类型转换包括强制(显式)和自动(隐式)转换。Number()将值转换为数值,如空字符串转0,非数字字符串转NaN。parseInt()遇到非数字字符停止转换。String()将任何值转为字符串,Boolean()转为布尔值,其中多数非零值转为true。隐式转换主要在比较、布尔值需求和算术运算时发生,例如在加法运算中,非字符串会与字符串拼接,其他运算符会将值转为数值。
摘要由CSDN通过智能技术生成

概述

JS中有六种简单数据类型:undefinednullbooleanstringnumbersymbol,以及引用类型:object

但是我们在声明的时候只有一种数据类型,只有到运行期间才会确定当前类型let x = y ? 1 : a;x的值在编译阶段是无法获取的,只有等到程序运行时才能知道

虽然变量的数据类型是不确定的,但是各种运算符对数据类型是有要求的,如果运算子的类型与预期不符合,就会触发类型转换机制

常见的类型转换有:强制转换(显示转换),自动转换(隐式转换)

显示转换

显示转换:我们可以很清楚的看到这里发生了类型的转变。

常见的方法有:Number(),parseInt(),String(),Boolean()。

Number()

将任意类型的值转化为数值

转换规则:

示例:

 Number(123) // 123// 字符串:可以被解析为数值,则转换为相应的数值Number('324') // 324// 字符串:不可以被解析为数值,返回 NaNNumber('324abc') // NaN// 空字符串转为0Number('') // 0// 布尔值:true 转成 1,false 转成 0Number(true) // 1Number(false) // 0// undefined:转成 NaNNumber(undefined) // NaN// null:转成0Number(null) // 0// 对象:通常转换成NaN(除了只包含单个数值的数组)Number({a: 1}) // NaNNumber([1, 2, 3]) // NaNNumber([5]) // 5 

从上面可以看到,Number转换的时候是很严格的,只要有一个字符无法转成数值,整个字符串就会被转为NaN

parseInt()

parseInt相比Number,就没那么严格了,parseInt函数逐个解析字符,遇到不能转换的字符就停下来

 parseInt('32a3') //32 

String()

可以将任意类型的值转化成字符串

转换规则:

示例:

 // 数值:转为相应的字符串String(1) // "1"//字符串:转换后还是原来的值String("a") // "a"//布尔值:true转为字符串"true",false转为字符串"false"String(true) // "true"//undefined:转为字符串"undefined"String(undefined) // "undefined"//null:转为字符串"null"String(null) // "null"//对象String({a: 1}) // "[object Object]"String([1, 2, 3]) // "1,2,3" 

Boolean()

可以将任意类型的值转为布尔值。

转换规则:

示例:

 Boolean(null) // falseBoolean(undefined) // falseBoolean(0) // falseBoolean(NaN) // falseBoolean('') // falseBoolean([]) // trueBoolean({}) // trueBoolean(new Boolean(false)) // true 

隐式转换

在隐式转换中,我们可能最大的疑惑是 :何时发生隐式转换?

我们这里可以归纳为两种情况发生隐式转换的场景:

  • 比较运算(==!=><)、ifwhile需要布尔值地方
  • 算术运算(+-*/%

除了上面的场景,还要求运算符两边的操作数不是同一类型

自动转换为布尔值

在需要布尔值的地方,就会将非布尔值的参数自动转为布尔值,系统内部会调用Boolean函数

可以得出个小结:

  • undefined
  • null
  • false
  • +0
  • -0
  • NaN
  • “”

除了上面几种会被转化成false,其他都换被转化成true

自动转换成字符串

遇到预期为字符串的地方,就会将非字符串的值自动转为字符串

具体规则是:先将复合类型的值转为原始类型的值,再将原始类型的值转为字符串

常发生在+运算中,一旦存在字符串,则会进行字符串拼接操作

'5' + 1 // '51'
'5' + true // "5true"
'5' + false // "5false"
'5' + {} // "5[object Object]"
'5' + [] // "5"
'5' + function (){} // "5function (){}"
'5' + undefined // "5undefined"
'5' + null // "5null" 

自动转换成数值

除了+有可能把运算子转为字符串,其他运算符都会把运算子自动转成数值

'5' - '2' // 3
'5' * '2' // 10
true - 1// 0
false - 1 // -1
'1' - 1 // 0
'5' * []// 0
false / '5' // 0
'abc' - 1 // NaN
null + 1 // 1
undefined + 1 // NaN 

null转为数值时,值为0undefined转为数值时,值为NaN

最后

整理了75个JS高频面试题,并给出了答案和解析,基本上可以保证你能应付面试官关于JS的提问。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值