JavaScript 隐式类型转换

JavaScript 隐式类型转换

原文:https://blog.csdn.net/itcast_cn/article/details/82887895 程序员

 

· 1.1 隐式转换介绍面试

· 1.2 隐式转换规则数组

· 1.3 坑一:字符串链接符与算术运算符隐式转换规则混淆spa

· 1.4 坑二:关系运算符:会把其余数据类型转换成number以后再比较关系.net

· 1.5 坑三:复杂数据类型在隐式转换时会先转成String,而后再转成Number运算3d

· 1.6-坑四:逻辑非隐式转换与关系运算符隐式转换搞混淆对象

 

1.1-隐式转换介绍blog

· 在js中,当运算符在运算时,若是两边数据不统一,CPU就没法计算,这时咱们编译器会自动将运算符两边的数据作一个数据类型转换,转成同样的数据类型再计算。ip

        o 这种无需程序员手动转换,而由编译器自动转换的方式就称为隐式转换字符串

· 例如1 > "0"这行代码在js中并不会报错,编译器在运算符时会先把右边的"0"转成数字0`而后在比较大小

 

1.2-隐式转换规则

1. 转成string类型: +(字符串链接符)

2. 转成number类型:++/--(自增自减运算符) + - * / %(算术运算符) > < >= <= == != === !=== (关系运算符)

3. 转成boolean类型:!(逻辑非运算符)

 

1.3-坑一:字符串链接符与算术运算符隐式转换规则混淆

· 常见面试题以下

· 原理分析

 

1.4-坑二:关系运算符:会把其余数据类型转换成number以后再比较关系

常见面试题以下

· 原理分析

 

1.5-坑三:复杂数据类型在隐式转换时会先转成String,而后再转成Number运算

 

· 原理分析

 

1.6-坑四:逻辑非隐式转换与关系运算符隐式转换搞混淆

· 前方高能,请注意~

o 空数组的toString()方法会获得空字符串,而空对象的toString()方法会获得字符串`[object Object]` (注意第一个小写o,第二个大写O哟)

· 常见面试题

 

· 原理分析

 

 

 

附:JavaScript 真值表

在日常的习惯中,咱们应该尽量的使用 === 而不是 ==。同时,能够选择使用 typeof 或者 ts 来避免强制类型转换的错误。

 

============== End

相关文章
相关标签/搜索