面试官:你说说 JavaScript 中类型的转换机制
前言
面试官:“你说说 JavaScript 中类型的转换机制”
紧张的萌新:“字符串跟其他类型拼接会变成字符串...”
面试官:“...”
······
大家好,我是 CoderBin,又来到了面试官系列,本次讲解的是 JavaScript 中类型的转换机制。希望对大家有所帮助,谢谢! 如果文中有不对、疑惑的地方,欢迎在评论区留言指正🌻
高频面试总结
面试官系列文章
【1】面试官系列-专栏
一、概述
JS
中有六种简单数据类型:undefined
、null
、boolean
、string
、number
、symbol
PS: ES10 中的新特性 BigInt (任意精度整数),目前还处于 stage-4 阶段,不出意外即将成为 js 的第七种基本数据类型和第二个数字数据类型。
但是我们在声明的时候只有一种数据类型,只有到运行期间才会确定当前类型
上面代码中,x
的值在编译阶段是无法获取的,只有等到程序运行时才能知道
虽然变量的数据类型是不确定的,但是各种运算符对数据类型是有要求的,如果运算子的类型与预期不符合,就会触发类型转换机制
常见的类型转换有:
强制转换(显示转换)
自动转换(隐式转换)
二、显示转换
显示转换,即我们很清楚可以看到这里发生了类型的转变,常见的方法有:
Number()
parseInt()
String()
Boolean()
Number()
将任意类型的值转化为数值
先给出类型转换规则:
实践一下:
从上面可以看到,Number
转换的时候是很严格的,只要有一个字符无法转成数值,整个字符串就会被转为NaN
parseInt()
parseInt
相比Number
,就没那么严格了,parseInt
函数逐个解析字符,遇到不能转换的字符就停下来
String()
可以将任意类型的值转化成字符串
给出转换规则图:
实践一下:
Boolean()
可以将任意类型的值转为布尔值,转换规则如下:
实践一下:
三、隐式转换
在隐式转换中,我们可能最大的疑惑是 :何时发生隐式转换?
我们这里可以归纳为两种情况发生隐式转换的场景:
比较运算(
==
、!=
、>
、<
)、if
、while
需要布尔值地方算术运算(
+
、-
、*
、/
、%
)
除了上面的场景,还要求运算符两边的操作数不是同一类型
自动转换为布尔值
在需要布尔值的地方,就会将非布尔值的参数自动转为布尔值,系统内部会调用Boolean
函数
可以得出个小结:
undefined
null
false
+0
-0
NaN
""
除了上面几种会被转化成false
,其他都换被转化成true
自动转换成字符串
遇到预期为字符串的地方,就会将非字符串的值自动转为字符串
具体规则是:先将复合类型的值转为原始类型的值,再将原始类型的值转为字符串
常发生在+
运算中,一旦存在字符串,则会进行字符串拼接操作
自动转换成数值
除了+
有可能把运算子转为字符串,其他运算符都会把运算子自动转成数值
null
转为数值时,值为0
。undefined
转为数值时,值为NaN
往期推荐 💐 🌸 🌹 🌻 🌺 🍁
高阅读好文:
【3】Vue内置指令大全
【4】Vue常用修饰符大全
每文一句:少而不学,老而无识。
本次的分享就到这里,如果本章内容对你有所帮助的话欢迎点赞+收藏。文章有不对的地方欢迎指出,有任何疑问都可以在评论区留言。希望大家都能够有所收获,大家一起探讨、进步!
版权声明: 本文为 InfoQ 作者【CoderBin】的原创文章。
原文链接:【http://xie.infoq.cn/article/01449ddc4b47a8a79111df4b5】。文章转载请联系作者。
评论