美文网首页
JavaScript隐式类型转换小结

JavaScript隐式类型转换小结

作者: skylinety | 来源:发表于2018-02-01 20:29 被阅读0次

本文首发于我的个人网站http://blog.skyline.ink,欢迎各位大大访问.
作者水平有限,文章仅供参考,不对的地方希望各位及时指正,共同进步,不胜感激

转换规则

隐式转换为布尔值

如表
数据类型 转化成true 转化成false
String 非空字符 ""(空字符)
Number 非零 0与NaN
Object 非Null对象 null
undefined undefined

(注:调用Boolean()方法得到结果相同)


对象隐式转换规则

对象隐式转换成字符串或数字
0E0B74FDA0F7561D3AF96126F84DD4B3.png-content
不同对象调用toString()得到的结果
对象 调用toString()
普通对象 "[object Object]"
数组arr arr.join()
函数类 定义函数的代码
日期类 可读日期
正则对象 正则对象字面量的字符
  • 如果数组的某一项的值是null或者undefined,join()方法返回的结果以空字符串连接
  • 基本包装类型的引用类型用其字面量形式的值调用toString()
不同对象调用valueOf()得到的结果
  • 大多数对象,包括普通对象、数组、函数、正则简单返回对象本身
  • 日期对象返回19700101以来的毫秒数值
  • 基本包装类型的引用类型返回其字面量形式的值

其他隐式转换规则

转化成字符串 转化成数字 转化成布尔值
undefined "undefined" NaN false
null "null" 0 false
NaN "NaN" NaN false
[](空数组) "" 0 true
""(空字符串) "" 0 false
  • 布尔值转数字为0/1,转字符串为"true"/"false"
  • 数字转字符串加引号即可🙄
  • 字符串转数字,看去掉引号是否是数字即可🤣,否则为NaN
    (注:假装这样表述是很严谨的🤣,数字与字符串的相互转换不用表述大家都知道的)

开始转换

加号

表达式中有字符串
  • 其他类型隐式转换为字符串
  • 多个加号时,按照从左到右的顺序,两两进行计算
  • 只要表达式中如果有字符串,最终结果一定是字符串
  • 如果有复杂类型,先将复杂类型按照对象隐式转换规则转换成字符串
2 + "3"; // "23"
1 + 2 + "3"; // "33"
true + 2 + "3"; // "33"
1 + "2" + 3; // "123"

"2" + true; //"2true"

"2" + undefined; //"2undefined"
"2" + NaN //"2NaN"
'23' + {'a': 1} //"23[object Object]"

'23' + [1,3,{}, null, undefined, '', '2'] // "231,3,[object Object],,,,2"
[1,3,{}, null, undefined, '', '2'].toString() //"1,3,[object Object],,,,2"
23 + "1,3,[object Object],,,,2" //"231,3,[object Object],,,,2"
表达式中没有字符串
  • 如果没有复杂类型,其他类型隐式转换为数字
  • 如果有复杂类型,先将复杂类型按照对象隐式转换规则转换成原始值再按照如上规则计算
1 + [] //"1"
1 + [1] //"11"
1 + {a:'a'} //"1[object Object]"
null + null //0
true + {a:'a'} //"true[object Object]"
  • 注意undefined 转化成数字是NaN
typeof NaN //"number"
null + undefined //NaN
1 + undefined //NaN
  • 特殊注意
+ '3'      // 数字3

乘,除,取余,减

  • 其他类型会隐式转换为数字
1 - '5' //-4
1 - [2, 2] //NaN
1 - {a:1} //NaN
1- undefined //NaN
1 - [] //1
1 - [2, 2] //NaN
1 - null //1

比较运算符部分 > < >= <= ==

  • 数字vs其他,其他转化为数字
  • 布尔值vs其他,布尔值转数字,数字vs其他
  • 字符串vs字符串,按unicode依次比较(大写字母总是在小写字母之后)
  • 对象vs数字,对象vs字符串,将对象转化为转换成原始值,再进行比较。
  • 如果其中一个操作数是NaN,那么总是返回false(NaN和NaN是不相等的)
  • null 只和undefined是好基友(互相相等)
var x = NaN;
x === NaN; // false

undefined == "undefined" // false
null == "null" // false
null == 0 // false
null == false // false
undefined == 0 // false
undefined == false // false

参考资料

《JavaScript高级程序设计》

相关文章

  • JavaScript隐式类型转换小结

    本文首发于我的个人网站http://blog.skyline.ink,欢迎各位大大访问.作者水平有限,文章仅供参考...

  • javascript数据类型隐式转换

    javascript数据类型隐式转换 一、函数类 isNaN()改函数会对参数进行隐式的Number()转换,如果...

  • JavaScript精选练习(1)

    打印100以内的所有质数 写出斐波那契数列 如果对于隐式类型转换不太了解可以看看:JavaScript隐式类型转换

  • 类型转换

    在JavaScript中,共有两种类型转换:隐式类型转换,显示类型转换。 “字符串”转换为“数字” 在JavaSc...

  • js类型转换

    javaScript类型转换 标签(空格分隔): 未分类 隐式转换 当遇到以下几种情况,JavaScript会自动...

  • JavaScript预编译

    JavaScript预编译,你不知道的JavaScript 隐式类型转换 typeof   typeof 用来校验...

  • 前端常见面试题(十三)@郝晨光

    列举三种强制类型转换和两种隐式类型转换 JavaScript是一门弱类型语言,在JavaScript中声明变量不需...

  • JavaScript的强制类型转换

    强制类型转换 将javascript的值从一种类型转换为另一种类型的值——>类型转换隐式类型转换——>强制类型转换...

  • 03.【JS怪癖1】隐式类型转换

    参考资料:JavaScript 的怪癖 1:隐式类型转换 1.布尔值的隐式转换 1.1 转为false 四种情况:...

  • 数据类型转换

    写在前面 C/C++编程中常见数据类型转换,包括隐式类型转换和显式类型转换。 1. 隐式类型转换 隐式类型转换在以...

网友评论

      本文标题:JavaScript隐式类型转换小结

      本文链接:https://www.haomeiwen.com/subject/gsjjzxtx.html