js每日一问(3)

51 阅读2分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第12天,点击查看活动详情

一。谈谈 JavaScript 中的类型转换机制

常见的类型转换有:

  • 强制转换(显示转换)
  • 自动转换(隐式转换)

1.显示转换:手动通过以下方法对数据进行转换

  • Number() 将任意类型的值转化为数值
  • parseInt() 将任意类型的值转化为整数
  • parseFloat() 将任意类型的值转化为浮点数
  • String() 可以将任意类型的值转化成字符串
  • Boolean() 可以将任意类型的值转为布尔值

2.隐式转换:在运算的过程中自己发生了转换

转换的场景:

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

自动转换为布尔值: 在比较运算 或者 判断语句中 会转数据转为布尔值

if(undefined){}  // 这里会将undefined转为false
// 自动转为false的值有:undefined,null,false,0,NaN,""
// 其他都换被转化成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

二。 == 和 ===区别,分别在什么情况使用

== 是等于操作符:

比较的是两个数据的值是否相等,如果比较的两个数据类型不同,会帮你做自动类型转换。

=== 是全等操作符:

比较的两个数据的值和类型必须完全相等。

三。深拷贝浅拷贝的区别?如何实现一个深拷贝?

浅拷贝:拷贝一层,深层次的引用类型则共享内存地址。

深拷贝:拷贝所有层,深层次的引用类型都具有自己独立的堆空间。

  • _.cloneDeep lodash.js的一个方法
  • jQuery.extend() jQuery的一个方法
  • JSON.stringify()
  • 手写循环递归