隐式类型转换的触发场景

2019-10-27  本文已影响0人  游游方

何为隐式类型转换

原出处

        在认识js的过程中因为总是会在突然的一个知识点中蹦出一个隐式类型转换,虽说在当时可以清楚地理解,但在后面学习其他知识,却会逐渐淡忘,所以我把自己接触到的一些会触发隐式类型转换的场景做一些总结。

                    触发隐式转换触发场景一、算术运算符+ - * / %

在此场景之下又可以分为两类不同的隐式转换

1.+运算符

 例:

图一 图二

图一所示,两个字符相加,不会实现数值一样加法,而是进行了拼接。

图二所示,此时的变量b已经变成了一个数值,但结果还是74,那我们根据图一可以得出一个结论,一个字符在和其他数据类型进行+运算时,另一个数据类型会转变成字符然后进行拼接,触发了隐式转换

2.- * / %运算符

        相比于+运算符,- * / %就显得单纯,因为他们只有一个运算功能

例:

字符与数值的运算

        如图所示,有两个变量,一个为字符,一个为数值。看其结果,他们很明显进行了运算,问题来了,一个是字符,一个是数值,他们是如何进行运算呢?结论就是他们触发了隐式转换,字符转换成了数值,进行运算。

1.字符与字符的运算

我们把b也换成字符,结果一样,都触发了隐式转换,把字符当做数值进行了处理。

2.字符与字符的运算

        我们把字符里的内容换成其他内容,输出结果为NaN非法的数值运算,我把最后一个NaN 进行了类型检测,类型还是为数值。

以上面介绍的都是字符与数值计算存在的区别差异,下面介绍一下另一种情况。算术运算符里存在的共同性。

数值与布尔的运算

        在数值与布尔的运算中,触发的隐式转换是先把布尔转换为数值类型,true=1,false=0;然后就按照正常运算输出结果。

        算数运算符中隐式转换先写到这,我写的这些并不完整,还有许多数据类型的运算没说到,不过不会随时补充的,下面说第二个场景。

                    触发场景二、if语句

       例: if(1)(  alert("会弹出来么?");)  答案:会

        我们知道if后面的括号里的条件是用来判断布尔值的,条件为真回输出,假则停止,而我们在例子的条件只是一个数字,为什么会输出真呢。

        if()中只需要布尔值,那么在if判断中,会把括号内所有的数据类型,转换成布尔值。

        if()隐式类型转换的规则如下

        数值:非0为true

        字符:非空为true

        对象,数组,函数:true

        undefined,NaN,null:为false

上一篇 下一篇

猜你喜欢

热点阅读