写点什么

面试官:你说说 JavaScript 中类型的转换机制

作者:CoderBin
  • 2022-10-21
    广东
  • 本文字数:2021 字

    阅读完需:约 1 分钟

面试官:你说说JavaScript中类型的转换机制

前言

面试官:“你说说 JavaScript 中类型的转换机制”


紧张的萌新:“字符串跟其他类型拼接会变成字符串...”


面试官:“...”


······


大家好,我是 CoderBin,又来到了面试官系列,本次讲解的是 JavaScript 中类型的转换机制。希望对大家有所帮助,谢谢! 如果文中有不对、疑惑的地方,欢迎在评论区留言指正🌻


高频面试总结

【1】关于Vue的一些高频面试题总结

【2】75道关于CSS的高频面试题总结,请注意查收!🔥

面试官系列文章

【1】面试官系列-专栏

一、概述

JS 中有六种简单数据类型:undefinednullbooleanstringnumbersymbol


PS: ES10 中的新特性 BigInt (任意精度整数),目前还处于 stage-4 阶段,不出意外即将成为 js 的第七种基本数据类型和第二个数字数据类型。


但是我们在声明的时候只有一种数据类型,只有到运行期间才会确定当前类型


let x = y ? 1 : a;
复制代码


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


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


常见的类型转换有:


  • 强制转换(显示转换)

  • 自动转换(隐式转换)

二、显示转换

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


  • Number()

  • parseInt()

  • String()

  • Boolean()

Number()

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


先给出类型转换规则:



实践一下:


Number(324) // 324
// 字符串:如果可以被解析为数值,则转换为相应的数值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(undefined) // falseBoolean(null) // 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' // 10true - 1  // 0false - 1 // -1'1' - 1   // 0'5' * []    // 0false / '5' // 0'abc' - 1   // NaNnull + 1 // 1undefined + 1 // NaN
复制代码


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

往期推荐 💐 🌸 🌹 🌻 🌺 🍁

高阅读好文


【1】关于Vue的一些高频面试题总结


【2】75道关于CSS的高频面试题总结,请注意查收!🔥


【3】Vue内置指令大全


【4】Vue常用修饰符大全


【5】面试官:你说说 js 中实现继承有哪几种方法?


----- 🌻 查看全部 🍁 -----




每文一句:少而不学,老而无识。


本次的分享就到这里,如果本章内容对你有所帮助的话欢迎点赞+收藏。文章有不对的地方欢迎指出,有任何疑问都可以在评论区留言。希望大家都能够有所收获,大家一起探讨、进步!

发布于: 刚刚阅读数: 4
用户头像

CoderBin

关注

不念过往,不惧将来 2020-10-14 加入

普通人只考虑他们将如何度过时间,而有智慧的人则试图利用时间 — CoderBin

评论

发布
暂无评论
面试官:你说说JavaScript中类型的转换机制_JavaScript_CoderBin_InfoQ写作社区