`

==与===详解

js 
阅读更多

    在做项目的时候遇到的,看了一些博客后,特地分享一下,做个记录,供以后查看。

 

     js中   == 与 === 区别

 

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

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

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

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

   进行“指针地址”比较

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

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

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

 

    使用“==”时,如果两边类型不同,js引擎会把他们转换成相同类型然后在进行比较,“===”则不会进行类型转换,因此当两边不是属于同一个类型,结果不相等。例如:

    var a = 0, b = '0';

    alert(( a==b ) + '--' + ( a===b ));

    此时看到的结果为“true--false”。

 

    ===判断规则

1.如果类型不同,就不相等

2.如果两个都是数值,并且是同一个值,那么相等;(!例外)的是,如果其中至少一个是NaN,那么不相等。(判断一个值是否是NaN,只能用isNaN()来判断)

3.如果两个都是字符串,每个位置的字符都一样,那么相等,否则不相等

4.如果两个值都是true,或者都是false,那么相等

5.如果两个值都引用同一个对象或函数,那么相等,否则不相等

6.如果两个值都是null,或者都是undefined,那么相等

    ==判断规则

1.如果两个值类型相同,进行===比较

2.如果两个值类型不同,他们可能相等。根据下面规则进行类型转换再比较:

    ①如果一个是null、一个是undefined,那么相等

    ②如果一个是字符串,一个是数值,把字符串转换成数值再进行比较

    ③如果任一值时true,把它转换成1再比较;如果任一值时false,把它转换成0再进行比较

    ④如果一个是对象,另一个是数值或字符串,把对象转换成基础类型的值再比较。对象转换成基础类型,利用它的toString或者valueOf方法。js核心内置类,会尝试valueOf先于toString;例外的是Date,Date利用的是toString转换。非js核心的对象,

    ⑤任何其他组合,都不相等

 

特别需要注意的是true、false的转换,例如:

    alert(true == 1) ;      //true

    alert(true == 2) ;      //false,  true会转换成number,也就是1,当然1不等于2

    //可以使用!!来把一个数据类型转换为boolean型

    alert( true == !!2 )    //true,    !2===false !(!=2) = !false = true

    另外在js中,如果把一个变量用在逻辑运算中,那么变量再无初始值或者其值为0、-0、null、""、false、undefined或者NaN时,它的值为false。否则,其值为true。

 

分享到:
评论

相关推荐

    AD问题详解==============

    AD问题详解==========================

    ========PCB封装形式详解========

    关于PCB封装的资料,非常详细,总共五个章节。 第一章节:概述(9个小节) 第二章节:陶瓷封装(8个小节) 第三章节:塑料封装(9个小节) 第四章节:金属封装(7个小节) 第五章节:其他封装(5个小节) ...

    visio流程图制作=详解.ppt

    visio流程图制作=详解.ppt

    Java_详解_1、==和Equal

    Java_详解_1、==和Equal用法与比较

    JavaScript里 ==与===区别详解

    1、对于string,number等基础类型,==和===是有区别的 1)不同类型间比较,==之比较“转化...以上所述是小编给大家介绍的JavaScript里 ==与===区别详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时

    java中hashcode()和equals()和==的详解

    有许多人学了很长时间的Java,但一直不明白hashCode方法的作用以及equals()和==的区别,我来解释一下吧。首先,想要明白hashCode的作用,你必须要先知道Java中的集合。总的来说,Java中的集合(Collection)有两类,...

    MFC中文帮助 MFC类库详解

    MFC中文帮助==================== MFC类库详解===============================

    【0分】【详细书签】【非扫描】TCP-IP详解卷一:协议

    TCP-IP详解卷一:协议 ========================================================= csh提供的电子书目录: ... ...电子书定期更新,低资源分。 ===========================...非扫描文字版,无限清晰且方便检索与拷贝内容!

    《HTML5开发精要与实例详解》配套源码

    此为《HTML5开发精要与实例详解》的全部配套源码 本书由资深Web开发专家亲自执笔,内容的权威性上应该是毋庸置疑的。 本书在内容结构上将继承《HTML 5与CSS 3权威指南》一书的优点,几乎每个知识点都将配一个精心...

    python中is与双等于号“==”的区别示例详解

    前言 在开始本文之前,首先要知道Python中对象包含的三个基本要素,分别是:id(身份标识)、python type()(数据类型)和value(值)。is和==都是对对象进行比较判断作用的,但对对象比较判断的内容并不相同。...

    Maven的Dependency详解

    命令参数详解: mvn install:install-file: maven 安装命令 -D groupId : 包名(在repository里面会建立一个如org/zenika/widget方件夹) -D artivactId: artifact 写你的jar名称 -D version:版本号名称 -D packaging...

    详解pandas.DataFrame.plot() 画图函数

    首先看官网的DataFrame.plot( )函数 DataFrame.plot(x=None, y=None, kind='line', ax=None, subplots=False, sharex=None, sharey=False, layout=None,figsize=None, use_index=True, title=None, grid=None, ...

    .Net Framework 3.5开发技术详解

    .Net Framework 3.5开发技术详解高清完整扫描版。 ================================================ 内容简介 本书全面讲解了.NET Framework 3.5开发中各方面的技术要点,共分19章。本书没有对各个功能的工作原理...

    51单片机编程基础与开发实例详解.ISO

    /***********检测放纸是否正确,是否存在纸张:******************************/ #include #include #include sbit PAPER=P1^5; /*纸张检测端口*/ void main(void) {  delay(200); ... while(PAPER==1);...

    Visual C++游戏开发经典案例详解.pdf

    Visual C++游戏开发经典案例详解.pdf

    numpy库与pandas库axis=0,axis= 1轴的用法详解

    主要介绍了numpy库与pandas库axis=0,axis= 1轴的用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

    详解js中==与===的区别

    为了减少概念混淆,应该把 =称作(得到或者赋值),==称作(相等),===称作(严格相等) 相同点: 它们两个运算符都允许任意类型的的操作数,如果操作数相等,返回true,否则返回false 不同: ...

Global site tag (gtag.js) - Google Analytics