JavaScript中相等和全等操作符的差异
2016-06-22 14:48
573 查看
1.相等和不相等操作符
==和!==会先转换操作数(即强制转型),然后再比较它们的相等性。
如果有一个操作数是布尔值,则在比较相等性之前先转换为数值——false转化为0,true转化为1;
如果有一个操作数是字符串,另一个是数值,则把字符串转换为数值再进行比较;
如果有一个操作数是对象,另一个不是,则自动调用对象的valueOf()方法,用得到的基本数据类型按照前面的规则比较
null和undefined是相等的;
要比较相等性之前,不能将null和undefined转换成其他任何值;
如果有一个操作数或者两个都是NaN,相等操作符返回false,不相等操作符返回true;
如果两个都是对象,则比较他们两个是不是同一个对象,指向同一个对象为true,否则false;
例如:
2.全等和不全等操作符
===和!=== 不进行转换直接进行比较;
例如:
为了保持代码中数据类型的完整性,推荐使用===和!===
==和!==会先转换操作数(即强制转型),然后再比较它们的相等性。
如果有一个操作数是布尔值,则在比较相等性之前先转换为数值——false转化为0,true转化为1;
如果有一个操作数是字符串,另一个是数值,则把字符串转换为数值再进行比较;
如果有一个操作数是对象,另一个不是,则自动调用对象的valueOf()方法,用得到的基本数据类型按照前面的规则比较
null和undefined是相等的;
要比较相等性之前,不能将null和undefined转换成其他任何值;
如果有一个操作数或者两个都是NaN,相等操作符返回false,不相等操作符返回true;
如果两个都是对象,则比较他们两个是不是同一个对象,指向同一个对象为true,否则false;
例如:
null == undefinded //true 'NaN' == NaN //false true == 1 //true true == 2 //false '5' == 5 //true null == 0 //false
2.全等和不全等操作符
===和!=== 不进行转换直接进行比较;
例如:
var result1 = ('55' == 55); //true, 转化后比较所以相等 var result2 = ('55' === 55); //false,数据类型不同,所以不相等
为了保持代码中数据类型的完整性,推荐使用===和!===
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- Python动态类型的学习---引用的理解
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解