JavaScript中的隐式类型转换
2014-06-15 12:33
711 查看
如果把通过函数或方法调用,明确的将某种类型转换成另一种类型称为显示转换 ,相反则称为隐式类型转换 。google和维基百科中没有找到“显示类型转换”,“隐式类型转换”的字眼。暂且这么称呼。
一、 运算中存在的隐式类型转换
1, “+”运算符
这里引擎将会先把a变成字符串"11"再与b进行连接,变成了"1122"。有人会有疑问,为什么不把b变成数字22再进行算术加运算呢,这样的话c就是33了。没有为什么,当运算符“+”两边一个是数字类型,一个是字符串类型时,js引擎规定进行字符串连接运算而非算术加运算。利用运算符“+”这个特性,可以很方便的将Number转换成String。如
2,“-”运算符
“-”可以是一元运算符(取负),也可以是二元(减法运算)的。如
这里与上面的“+”相反,会把字符串b隐式的转换成数字5再进行算术减法运算。利用这个特性,可以很方便的将String转换成Number
二、 语句中存在的隐式类型转换
1,if
这里会把obj隐式的转换成Boolean类型
2,while
同if
3,for in时的类型转换
定义对象字面量时发生从标识符到字符串的隐式转换。
这里name,age分别加单/双引号以强调其为String类型,school没有加单/双引号。我们遍历下该对象的属性,查看其类型。发现school也被隐式的转换成了String类型。
数组的索引其实也是字符串类型。这着实令人惊叹,但事实的确如此。如
三、 alert时存在的隐式类型转换
给String原型上添加了个fn方法,该方法返回this,我们知道this可以理解成当前类的实例对象,既然是对象那么typeof a.fn()自然返回是object了。
关键是最后的alert(a.fn()),a.fn()返回的明明是对象,但却隐式的转换成了字符串“hello”显示。
同样的情况发生在数字类型上,如
a.fn()返回的是对象类型,但在alert(a.fn())时会隐式的将其转换成数字。
一、 运算中存在的隐式类型转换
1, “+”运算符
“-”可以是一元运算符(取负),也可以是二元(减法运算)的。如
1,if
2,while
3,for in时的类型转换
定义对象字面量时发生从标识符到字符串的隐式转换。
数组的索引其实也是字符串类型。这着实令人惊叹,但事实的确如此。如
关键是最后的alert(a.fn()),a.fn()返回的明明是对象,但却隐式的转换成了字符串“hello”显示。
同样的情况发生在数字类型上,如
相关文章推荐
- JavaScript 类型的隐式转换
- 「译」JavaScript 的怪癖 1:隐式类型转换
- JavaScript隐式类型转换
- JavaScript基础之数据类型的隐式转换
- JavaScript-数据类型-隐式转换1
- 「译」JavaScript 的怪癖 1:隐式类型转换
- JavaScript显式类型转换与隐式类型转换
- 有趣的JavaScript隐式类型转换
- 简单介绍JavaScript数据类型之隐式类型转换
- javascript:第四章 数据类型显示和隐式的转换
- 浅析JavaScript中的隐式类型转换
- javascript数据类型隐式转换
- JavaScript隐式类型转换
- JavaScript隐式类型转换
- JavaScript复习之--javascript数据类型隐式转换
- JavaScript复习之--javascript数据类型隐式转换
- JavaScript隐式类型转换趣解
- JavaScript中的隐式类型转换
- JavaScript之数据类型转换——隐式转换与运算符
- JavaScript的隐式类型转换