浅析Javascript中双等号(==)隐性转换机制


Posted in Javascript onOctober 27, 2017

在Javascript中判断相等关系有双等号(==)和三等号(===)两种。其中双等号(==)是值相等,而三等号(===)是严格相等(值及类型是否完全相等)。

因此有几个常识知识:

1、对于string,number等基础类型,==和===是有区别的

1)不同类型间比较,==之比较“转化成同一类型后的值”看“值”是否相等,===如果类型不同,其结果就是不等

2)同类型比较,直接进行“值”比较,两者结果一样

2、对于Array,Object等高级类型,==和===是没有区别的

进行“指针地址”比较

3、基础类型与高级类型,==和===是有区别的

1)对于==,将高级转化为基础类型,进行“值”比较

2)因为类型不同,===结果为false

换句话说,双等号(==)在运算的时候会进行类型转换,而三等号(===)则不会。

如:

alert('55' == 55); //true
alert('55' === 55); //false

Javascript语言中五大基本数据类型(原始值,也叫简单数据类型):即 Undefined、Null、Boolean、Number 和 String 型。由于这些原始类型占据的空间是固定的,所以可将他们存储在较小的内存区域 - 栈中。这样存储便于迅速查寻变量的值;

Javascript中使用双等号(==)判断相等的隐性转换机制:

1,如果两边都是简单类型:

1,1,两边都是简单类型,且类型相同,则直接进行比较。

console.log(1==1); //true
console.log("1"=="1"); //true
console.log(false==false); //true
console.log(null==null); //true
console.log(undefined==undefined); //true

1.2,两边都是简单类型,类型不同,则先转换为数字比较(其中Boolean只有两个值:true==1,false==0;null与undefined相等;字符串数字等于数字值,空字符串""==0;)

console.log(1==true); //true
console.log(0==false); //true
console.log(1=="1"); //true
console.log(0==""); //true
console.log(0==null); //false
console.log(0==undefined); //false
console.log(null==undefined); //true

2,如果一边是简单类型,另一边是引用类型(高级类型),则高级类型隐式转换成简单类型再比较。

console.log(Object==Object); //true
console.log(Object=={}); //false
console.log(0=={}); //false
console.log(0==[]); //true
console.log(Array==Array); //true
console.log(Object==Array); //false

3,如果两边都是引用类型(高级类型),则进行进行“指针地址”比较。

重点-toString()和valueOf()

很多人看到这两个方法的第一感觉就是,toString()方法将一个对象转化为字符串,valueOf方法将一个对象转化为数值。

这种想法很片面,我们通过以下两个例子来看看:

var obj={
  name:"熊仔其人",
  getName:function(){ return $(this).name; }
};
console.log(obj.toString()); //[object Object]

定义一个obj对象,调用它的toString方法,返回值是[object Object],发现并未像我们想象的一样返回值其内容的字符串表示。

var arr=[1,2,3];
console.log(arr.valueOf()); //(3) [1, 2, 3]

定义一个数组arr,调用它的valueOf方法,返回值是[1, 2, 3],发现也并未像我们想象的一样返回数值类型的表示。

其实真正的理解是这样的:调用对象的toString()方法可以将对象转化为字符串,但是如果要转化为字符串不一定是调用toString方法。

我们再看看下面的代码。

var obj= { };   
obj.valueOf=function(){ return 1; }
obj.toString=function(){ return 2; }
console.log(obj==1);  //true
var obj2= { };   
obj2.valueOf=function(){ return 2; }
obj2.toString=function(){ return 1; }
console.log(obj2==1);  //false                                      
var obj3={ };
obj3.valueOf=function(){ return []; }
obj3.toString=function(){ return 1; }
console.log(obj3==1);  //true

上述代码中我们定义了一个对象obj,obj2,定义了valueOf和toString方法的返回值,通过与1比较相等,发现其优先调用了valueOf方法。

然后定义了一个对象obj3,定义了valueOf和toString方法的返回值,通过与1比较相等,发现其调用的是toString方法。

然后我们看下面一段代码:

var obj= { };   
obj.valueOf=function(){ return 'a'; }
obj.toString=function(){ return 2; }
console.log(obj=='a');  //true
var obj2= { };   
obj2.valueOf=function(){ return 'b'; }
obj2.toString=function(){ return 'a'; }
console.log(obj2=='a');  //false

上述代码2中定义一个对象obj,通过与字符串'a'比较发现其调用的是valueOf方法。

然后对象obj2与'a'的比较返回false,发现其并未调用toString方法。

由此我们可以得出结论:

对象转化为简单类型时会优先调用valueOf方法,如果可以与简单值进行比较则会直接比较,此时不再调用toString方法。如果调用valueOf方法后无法与简单值进行比较,则会再调用toString方法,最终得到比对的结果。

但是需要注意的一点是Date对象不满足上述的规则,Date对象的toString和valueOf方法都是重新定义过的,默认会调用toString方法。

PS:js的双等号隐式转换规则

使用双等号进行比较的时候,当两个操作数类型不一样时,双等号会进行一个隐式转换,转换成相同类型再比较,以下是转换规则,在红宝书P51页都能查到。(自己总是忘记,还是感觉好记性不如烂笔头,写一写总是影响深刻)

1、有一个操作数为布尔值,将布尔值转换成数值再进行比较,false为0,true为1.

2、一个为字符串,另一个为数字。将字符串转换成数值再进行比较。

3、一个操作符为对象,另一个不是对象,先利用 valueOf() 得到对象值得类型,再按照其他规则进行比较。

总结

以上所述是小编给大家介绍的Javascript中双等号(==)隐性转换机制,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript 数组的方法集合
Jun 05 Javascript
不同的jQuery API来处理不同的浏览器事件
Dec 09 Javascript
js 延迟加载 改变JS的位置加快网页加载速度
Dec 11 Javascript
深入理解javascript构造函数和原型对象
Sep 23 Javascript
JavaScript中的变量作用域介绍
Dec 31 Javascript
简介可以自动完成UI的AngularJS工具angular-smarty
Jun 23 Javascript
BootstrapTable与KnockoutJS相结合实现增删改查功能【一】
May 10 Javascript
jQuery实现根据生日计算年龄 星座 生肖
Nov 23 Javascript
JS HTML图片显示Canvas 压缩功能
Jul 21 Javascript
微信小程序tab切换可滑动切换导航栏跟随滚动实现代码
Sep 04 Javascript
vue项目使用$router.go(-1)返回时刷新原来的界面操作
Jul 26 Javascript
OpenLayers3实现对地图的基本操作
Sep 28 Javascript
微信小程序promsie.all和promise顺序执行
Oct 27 #Javascript
JS+CSS实现网页加载中的动画效果
Oct 27 #Javascript
vue-resource拦截器设置头信息的实例
Oct 27 #Javascript
Vue-resource拦截器判断token失效跳转的实例
Oct 27 #Javascript
vue2里面ref的具体使用方法
Oct 27 #Javascript
初学者AngularJS的环境搭建过程
Oct 27 #Javascript
JavaScript中Require调用js的实例分享
Oct 27 #Javascript
You might like
ThinkPHP3.0略缩图不能保存到子目录的解决方法
2012/09/30 PHP
PHP常用特殊运算符号和函数总结(php新手入门必看)
2013/02/02 PHP
php根据用户语言跳转相应网页
2015/11/04 PHP
PHP对称加密算法(DES/AES)类的实现代码
2017/11/14 PHP
form表单中去掉默认的enter键提交并绑定js方法实现代码
2013/04/01 Javascript
js处理php输出时间戳对不上号的解决方法
2014/06/20 Javascript
javascript实现全局匹配并替换的方法
2015/04/27 Javascript
详解JavaScript基本类型和引用类型
2015/12/09 Javascript
Bootstrap模态窗口源码解析
2017/02/08 Javascript
jQuery实现简单弹窗遮罩效果
2017/02/27 Javascript
小程序实现搜索界面 小程序实现推荐搜索列表效果
2019/05/18 Javascript
通过JS深度判断两个对象字段相同
2019/06/14 Javascript
python socket网络编程步骤详解(socket套接字使用)
2013/12/06 Python
python实现sublime3的less编译插件示例
2014/04/27 Python
深入讲解Java编程中类的生命周期
2016/02/05 Python
Numpy中矩阵matrix读取一列的方法及数组和矩阵的相互转换实例
2018/07/02 Python
Selenium+Python 自动化操控登录界面实例(有简单验证码图片校验)
2019/06/28 Python
django+echart数据动态显示的例子
2019/08/12 Python
python将字母转化为数字实例方法
2019/10/04 Python
Python实现线性判别分析(LDA)的MATLAB方式
2019/12/09 Python
python实现字典嵌套列表取值
2019/12/16 Python
Python爬虫库requests获取响应内容、响应状态码、响应头
2020/01/25 Python
浅谈Tensorflow加载Vgg预训练模型的几个注意事项
2020/05/26 Python
全球最大的在线橄榄球商店:Lovell Rugby
2018/05/20 全球购物
会计专业自我评价
2014/02/12 职场文书
计算机专业职业规划
2014/02/28 职场文书
学习2014年全国两会心得体会
2014/03/12 职场文书
投资合作协议书范本
2014/04/17 职场文书
医生学习党的群众路线教育实践活动心得体会
2014/11/03 职场文书
商业门面租房协议书
2014/11/25 职场文书
初中同学会致辞
2015/08/01 职场文书
家长对孩子的寒假评语
2015/10/09 职场文书
2016年保险公众宣传日活动总结
2016/04/05 职场文书
详解CSS中的特指度和层叠问题
2021/07/15 HTML / CSS
JavaWeb 入门:Hello Servlet
2021/07/16 Java/Android
bat批处理之字符串操作的实现
2022/03/16 Python