浅析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 相关文章推荐
[JS]点出统计器
Oct 11 Javascript
javascript removeChild 使用注意事项
Apr 11 Javascript
jQuery 对Select的操作备忘记录
Jul 04 Javascript
js快速排序的实现代码
Dec 08 Javascript
JS实现在页面随时自定义背景颜色的方法
Feb 27 Javascript
利用n 升级工具升级Node.js版本及在mac环境下的坑
Feb 15 Javascript
纯JS实现轮播图
Feb 22 Javascript
jquery实现静态搜索功能(可输入搜索文字)
Mar 28 jQuery
微信小程序中做用户登录与登录态维护的实现详解
May 17 Javascript
JS中使用textPath实现线条上的文字
Dec 25 Javascript
如何优雅地在Node应用中进行错误异常处理
Nov 25 Javascript
使用 Github Actions 自动部署 Angular 应用到 Github Pages的方法
Jul 20 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
咖啡的植物学知识
2021/03/03 咖啡文化
php基础知识:类与对象(5) static
2006/12/13 PHP
php开启安全模式后禁用的函数集合
2011/06/26 PHP
ThinkPHP在新浪SAE平台的部署实例
2014/10/31 PHP
php查询相似度最高的字符串的方法
2015/03/12 PHP
浅谈PHP各环境下的伪静态配置
2019/03/13 PHP
PHP实现笛卡尔积算法的实例讲解
2019/12/22 PHP
js 关于=+与+=日期函数使用说明(赋值运算符)
2011/11/15 Javascript
javascript中xml操作实现代码
2011/11/21 Javascript
JQuery判断HTML元素是否存在的两种解决方法
2013/12/26 Javascript
JavaScript中的继承方式详解
2015/02/11 Javascript
聊一聊JavaScript作用域和作用域链
2016/05/03 Javascript
js操作数据库实现注册和登陆的简单实例
2016/05/26 Javascript
js轮播图代码分享
2016/07/14 Javascript
微信小程序开发之toast提示插件使用示例
2017/06/08 Javascript
详解vue-cli与webpack结合如何处理静态资源
2017/09/19 Javascript
详解Node.js利用node-git-server快速搭建git服务器
2017/09/27 Javascript
vee-validate vue 2.0自定义表单验证的实例
2018/08/28 Javascript
React+Redux实现简单的待办事项列表ToDoList
2019/09/29 Javascript
使用Node.js实现base64和png文件相互转换的方法
2020/03/11 Javascript
python实现给字典添加条目的方法
2014/09/25 Python
Python模拟登陆实现代码
2017/06/14 Python
Django实现的自定义访问日志模块示例
2017/06/23 Python
Python获取CPU、内存使用率以及网络使用状态代码
2018/02/08 Python
Python 内置函数进制转换的用法(十进制转二进制、八进制、十六进制)
2018/04/30 Python
使用TensorFlow实现SVM
2018/09/06 Python
新西兰领先的内衣店:Bendon Lingerie新西兰
2018/07/11 全球购物
美国班级戒指、帽子和礼服、毕业产品、年鉴:Balfour
2018/11/01 全球购物
Marlies Dekkers内衣法国官方网上商店:国际知名的荷兰内衣品牌
2019/03/18 全球购物
文员自我评价怎么写
2013/09/19 职场文书
《走一步再走一步》教学反思
2014/02/15 职场文书
新春文艺演出主持词
2014/03/27 职场文书
医院标语大全
2014/06/23 职场文书
一份关于丢失公司财物的检讨书
2014/09/19 职场文书
党员自我评议对照检查材料
2014/09/27 职场文书
python实现三次密码验证的示例
2021/04/29 Python