[转载]javascript 隐性类型转换步骤
2016-05-18 14:29
344 查看
来自:/article/4592236.html
这里说的隐性类型转换,是==引起的转换。
1、如果存在NaN,一律返回false
2、再看有没有布尔,有布尔就将布尔转换为数字
3、接着看有没有字符串, 有三种情况,对方是对象,对象使用toString进行转换;对方是数字,字符串转数字;对方是字符串,直接比较;其他返回false
4、如果是数字,对方是对象,对象取valueOf进行比较, 其他一律返回false
5、null, undefined不会进行类型转换, 但它们俩相等。
下面是些例子:
0 == undefined
1 == true
2 == {valueOf: function(){return 2}}
NaN == NaN
8 == undefined
1 == undefined
null == {toString: function(){return 2}}
0 == null
null == 1
{ toString:function(){ return 1 } , valueOf:function(){ return [] }} == 1
这里说的隐性类型转换,是==引起的转换。
1、如果存在NaN,一律返回false
2、再看有没有布尔,有布尔就将布尔转换为数字
3、接着看有没有字符串, 有三种情况,对方是对象,对象使用toString进行转换;对方是数字,字符串转数字;对方是字符串,直接比较;其他返回false
4、如果是数字,对方是对象,对象取valueOf进行比较, 其他一律返回false
5、null, undefined不会进行类型转换, 但它们俩相等。
下面是些例子:
0 == undefined
1 == true
2 == {valueOf: function(){return 2}}
NaN == NaN
8 == undefined
1 == undefined
null == {toString: function(){return 2}}
0 == null
null == 1
{ toString:function(){ return 1 } , valueOf:function(){ return [] }} == 1
相关文章推荐
- j2ee中的重定向和转发
- js的继承
- Javascript--装饰器模式和观察者模式
- [repost]State of the Art JavaScript in 2016
- 自动提取HTML中的JS进行合并与压缩
- js判断undefined类型
- ssh框架与json的整合,没导入相应jar包报的错误提示
- Angular JS中 Promise用法
- 理解Javascript中的变量作用域(scope)和语境(context)
- Extjs之自动消失提示框(Ext.example.msg)
- js file img 操作
- [js]关于闭包与访问数组下标的老生常谈
- Ajax跨域:jsonp还是CORS
- js将对象所有属性(都是数字,浮点小数),将其保留整数
- js求时间差
- JavaScript数组常用操作大全
- JavaScript编写Web脚本最佳实现
- JavaScript编写Web脚本最佳实现
- Javascript复习第七天 简陋的五子棋
- js修改隔行tr的颜色。