Javascript关于类型转换

Javascript关于类型转换

在Javascript中有六种简单数据类型:undefined、null、boolean、string、number、symbol,以及引用类型:Object

但是在声明的时候只有一种数据类型,只有运行的时候才会确定类型

let x = y ? 1 : a;

上述代码中,x的值在编译阶段是无法获取的,只有等到程序运行时才能够知道

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

常见的有:强制转换和隐式转换

显示转换(强制转换)

显示转换就是我们很清楚可以看到这里发生了类型的转变,常见的方法有:

Number()

parseInt()

String()

Boolean()

1.Number()

将任意类型的值转化为数值,下面是类型转换规则:

image-20240424123621395

实践一下:

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

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

2.parseInt()

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

parseInt('32a1') // 32
3.String()

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

image-20240424124630022

实践一下:

//数值:转为相应字符串
String(1) // "1"
//字符串:还是原来的值
String("a") // "a"
//布尔值:懂的都懂
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"
3.Boolean()
Boolean(undefined) // false
Boolean(null) // false
Boolean(0) // false
Boolean(NaN) // false
Boolean('') // false
Boolean({}) // true
Boolean([]) // true
Boolean(new Boolean(false)) // true
隐式转换

注意一个问题:何时会发生隐式转换?

可以归纳为两种情况:

1.比较运算(==、!=、>、<)、if、while需要布尔值的地方

2.算术运算(+、-、*、/、%)

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

自动转换为布尔值

在需要布尔值的地方,就会自动转换

自动转换为字符串

在预期遇到字符串的地方,就会自动转换

'5' + 1 // '51'
'5' + true // "5true"
'5' + false // "5false"
'5' + {} // "5[object Object]"
'5' + [] // "5"
'5' + function (){} // "5function (){}"
'5' + undefined // "5undefined"
'5' + null // "5null"
自动转换为数值

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

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值