zl程序教程

您现在的位置是:首页 >  前端

当前栏目

JAVASCRIPT学习笔记之强制类型转换

JavaScript笔记学习 强制 类型转换
2023-09-27 14:28:01 时间
最近在读《你不知道的javascript》系列图书,收获蛮大,感慨也挺多的。 是的,关于javascript,你不是不知道,而是真的不知道。 就比如类型转换,从开始到看完到第二第三第N遍,我经历了如下的心路历程: 这有什么不知道的 → 一脸懵逼 → 有点意思 → 卧槽,怎么这样? → 原来是这样 → 靠,还是坑... 真可谓是不学不知道,一学吓一跳。

最近在读《你不知道的javascript》系列图书,收获蛮大,感慨也挺多的。
是的,关于javascript,你不是不知道,而是真的不知道。
就比如类型转换,从开始到看完到第二第三第N遍,我经历了如下的心路历程:
这有什么不知道的 → 一脸懵逼 → 有点意思 → 卧槽,怎么这样? → 原来是这样 → 靠,还是坑...
真可谓是不学不知道,一学吓一跳。
为了避免再次入坑,这里做个总结,不,了结。

Javascript中的强制类型转换总是返回标量基本类型值(string, boolean, number, undefined, null)。
直白点就是toString()或者valueOf()的返回值。

toString和valueOf的区别 toString : 以字符串形式返回该对象的原始值 valueOf : 返回最适合该对象类型的原始值 在数值运算中,会优先调用valueOf 在字符串运算中,会优先调用toString
var a = 1;

a.toString() // 1

a.valueOf() // 1

a + 2 // 3 优先调用valueOf

a + string // 1string 优先调用toString

a +  //隐式强制类型转换

String(a) //显示强制类型转换

ToString 字符串化

对象在强制转换为字符串的时候,会优先调用toString()方法,如果返回基本类型的值,则直接使用该返回值;
如果返回值不是基本类型,则会继续调用valueOf()方法,如果valueOf()返回基本类型的值,则直接使用该返回值,否则报错。
数组默认的toString方法经过了重新定义,类似于数组的join(,)方法,会将数组的各个元素以,分隔返回。这就是String([]) ===  的原因。


字符串、数字、布尔、null的JSON.stringify的规则与ToString相同 如果传递给JSON.stringify的对象中定义了toJSON()方法,那么该方法会在字符串化前调用。
JSON.stringify({a : undefined, b : function () {}, c: 1}) // "{"c":1}"

JSON.stringify([undefined, function () {},1]) // "[null, null, 1]"

ToNumber 数字化

对象在强制转换为数字的时候,会优先调用valueOf()方法,如果返回基本类型的值,则直接使用该返回值;
如果返回值不是基本类型,则会继续调用toString()方法,如果toString()返回基本类型的值,则直接使用该返回值,否则报错。


Number([]),因为[].valueOf()返回值不是基本类型,因此会调用toString(), 等价于Number()

ToBoolean 布尔化

javascript有以下假值:

undefined false +0、-0 和 NaN

假值的布尔强制类型转化为false
可以理解为假值列表以外的都是真值(true)


== 允许在相等比较中进行强制类型转换,=== 不允许
== 和 === 都会检查操作数的类型,区别在于操作数类型不同时他们的处理方式不同,即== 会进行强制类型转换

容易懵逼的地方
null == undefined

NaN != NaN

null != 0

undefined != 0

NaN != 0

[] == false

[] == 0

[] == 

[] == ![]

正确的使用 ==
如果两边的值中有true或者false,千万不要使用 == 如果两边的值中有[]、或者0, 尽量不要使用 ==
水灵儿 www.zyl.me 爱折腾,喜欢造,花起钱来毫不心疼,事后沉默一周... 极简主义者,主从事Web开发兼前端爱好者。 全栈开发尝试者、自媒体、极简主义者、爱心极客