zoukankan      html  css  js  c++  java
  • javascript 中==和===的区别

        对于JavaScript中比较运算符,可能大家用的比较多的是“==”、对于“===”很多人可能很陌生。=== 表示恒等,首先比较两边的变量数据类型是否相等,其次比较两边的变量的数值是否相等;== 表示相等即仅仅比较两边变量的数值是否相等。

    一、“===”首先计算其操作数的值,然后比较这两个值,比较过程没有任何类型转换

    1、如果两个值类型不相同,则它们不相等。

    2、如果两个值都是null或者都是undefined,则它们不相等。

    3、如果两个值都是布尔值true或false,则它们相等。

    4、如果其中一个值是NaN,或者两个两个值都是NaN,则它们不相等。NaN和其他任何值都是不相等的,包括它本身!!!通过x!==x来判断x是否为NaN,只有在x为NaN的时候,这个表达式的值才为true。

    5、如果两个值为数字,且数值相等,则它们相等。如果一个为0,另一个为-0,则它们同样相等。

    6、如果两个值为字符串,且所含的对应位上的16位数完全相等,则它们相等。如果它们的长度或内容不同,则它们不等。两个字符串可能含义完全一样且所显示出手字符也一样,但具有不同编码的16位值。JavaScript并不对Unicode进行标准化的转换,因此像这样的字符串通过"==="和"=="运算符的比较结果也不相等。

    7、如果两个引用值同一个对象、数组或函数,则它们是相等的。如果指向不同的对象,则它们是不等的。尽管两个对象具有完全一样的属性。

    例如



    var param1= ‘1’, param2 = ‘1’ ;
    param1 === param2; //类型和数值同时相等 true
    var param3 = 1;
    param1 === param3; //类型不相等和数值相等false
    var param4 = 2;
    param1 === param4; //类型和数值都不相等 false


    var param1 = null, param2 = undefined;
    param1 === param2; //false

    二、 相等运算符“==”如果两个操作数不是同一类型,那么相等运算符会尝试一些类型转换,然后进行比较

    1、如果一个值是null,另一个是undefined,则它们相等。

    2、如果一个值是数字,另一个是字符串,先将字符串转换为数字,然后使用转换后的值比较。

    3、如果其中一个值是true,则将其转换为1再进行比较。如果其中一个值是false,则将基转换为0再进行比较。

    4、如果一个值是对象,另一个值是数字或字符串,则将对象转换为原始值,然后再进行比较。对象通过toString()方法或valueOf()方法转换为原始值。JavaScript核心的内置类首先尝试使用valueOf(),再尝试使用toString(),除了日期类,日期类只使用toString()转换。那些不是JavaScript语言核心中的对象则通过各自的实现中定义的方法转换为原始值。

    5、其他不同类型之间的比较均不相等.

    例如

    var param1= ‘1’, param2 = ‘1’ ;
    param1 == param2; //类型和数值同时相等true
    var param3 = 1;
    param1 == param3; //类型不相等和数值相等true
    var param4 = 2;
    param1 == param4; //类型和数值都不相等false

    var param1 = null, param2 = undefined;
    param1 === param2; //true

  • 相关阅读:
    Android:简单联网获取网页代码
    nginx搭建前端项目web服务器以及利用反向代理调试远程后台接口
    ElementUI使用问题记录:设置路由+iconfont图标+自定义表单验证
    vue中引入第三方字体图标库iconfont,及iconfont引入彩色图标
    Axios使用文档总结
    使用node中的express解决vue-cli加载不到dev-server.js的问题
    Vue脚手架(vue-cli)搭建和目录结构详解
    JS夯实基础:Javascript 变态题解析 (下)
    理解JS里的稀疏数组与密集数组
    JS夯实基础:Javascript 变态题解析 (上)
  • 原文地址:https://www.cnblogs.com/baizhanshi/p/4604257.html
Copyright © 2011-2022 走看看