飞道的博客

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

315人阅读  评论(0)

一、概述

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

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

let x = y ? 1 : a;

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

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

常见的类型转换有:

  • 强制转换(显示转换)

  • 自动转换(隐式转换)

二、显示转换

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

  • Number()

  • parseInt()

  • String()

  • Boolean()

Number()

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

先给出类型转换规则:

实践一下:


   
  1. Number( 324// 324
  2. // 字符串:如果可以被解析为数值,则转换为相应的数值
  3. Number( '324'// 324
  4. // 字符串:如果不可以被解析为数值,返回 NaN
  5. Number( '324abc'// NaN
  6. // 空字符串转为0
  7. Number( ''// 0
  8. // 布尔值:true 转成 1,false 转成 0
  9. Number( true// 1
  10. Number( false// 0
  11. // undefined:转成 NaN
  12. Number(undefined)  // NaN
  13. // null:转成0
  14. Number(null)  // 0
  15. // 对象:通常转换成NaN(除了只包含单个数值的数组)
  16. Number({a:  1})  // NaN
  17. Number([ 123])  // NaN
  18. Number([ 5])  // 5

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

parseInt()

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

parseInt('32a3'//32

String()

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

给出转换规则图:

实践一下:


   
  1. // 数值:转为相应的字符串
  2. String( 1// "1"
  3. //字符串:转换后还是原来的值
  4. String( "a"// "a"
  5. //布尔值:true转为字符串"true",false转为字符串"false"
  6. String( true// "true"
  7. //undefined:转为字符串"undefined"
  8. String(undefined)  // "undefined"
  9. //null:转为字符串"null"
  10. String(null)  // "null"
  11. //对象
  12. String({a:  1})  // "[object Object]"
  13. String([ 123])  // "1,2,3"

Boolean()

可以将任意类型的值转为布尔值,转换规则如下:

实践一下:


   
  1. Boolean(undefined)  // false
  2. Boolean(null)  // false
  3. Boolean( 0// false
  4. Boolean(NaN)  // false
  5. Boolean( ''// false
  6. Boolean({})  // true
  7. Boolean([])  // true
  8. Boolean( new Boolean( false))  // true

三、隐式转换

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

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

  • 比较运算(==!=><)、ifwhile需要布尔值地方

  • 算术运算(+-*/%

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

自动转换为布尔值

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

可以得出个小结:

  • undefined

  • null

  • false

  • +0

  • -0

  • NaN

  • ""

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

自动转换成字符串

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

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

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


   
  1. '5' +  1  // '51'
  2. '5' +  true  // "5true"
  3. '5' +  false  // "5false"
  4. '5' + {}  // "5[object Object]"
  5. '5' + []  // "5"
  6. '5' + function (){}  // "5function (){}"
  7. '5' + undefined  // "5undefined"
  8. '5' + null  // "5null"

自动转换成数值

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


   
  1. '5' -  '2'  // 3
  2. '5' *  '2'  // 10
  3. true -  1   // 0
  4. false -  1  // -1
  5. '1' -  1    // 0
  6. '5' * []     // 0
  7. false /  '5'  // 0
  8. 'abc' -  1    // NaN
  9. null +  1  // 1
  10. undefined +  1  // NaN

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


面试官JavaScript系列正在更新:4/33

面试官:说说JavaScript中的数据类型?区别?文末彩蛋!

面试官:Javscript数组的常用方法有哪些?

面试官:Javscript字符串的常用方法有哪些?

篇副有限,扫下方二维码查看往期


转载:https://blog.csdn.net/weixin_44475093/article/details/113697016
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场