搜索

首页  >  问答  >  正文

JavaScript中怎么理解=、==和===

JavaScript中怎么理解=、==和===,如何理清这三者之间的关系?

迷茫迷茫2763 天前1019

全部回复(6)我来回复

  • 大家讲道理

    大家讲道理2017-06-30 10:00:46

    = : 赋值操作

    ==: 用来判断两个值是否相等,但是这里的判断是经过隐式转换的结果。例如

    1 == '1';  // true
    1 == true; // true
    0 == false; // true

    ===: 也是用来判断两个值是否相等,但是不会有隐式转换的过程,而是直接判断,因此也叫做绝对相等/全等。

    1 === '1';  // false
    1 === true; // false
    0 === false; // false

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

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

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

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

    进行“指针地址”比较

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

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

    • 因为类型不同,===结果为false

    回复
    0
  • 我想大声告诉你

    我想大声告诉你2017-06-30 10:00:46

    '=': 表示赋值,

    var a = 1,
        b = 2;
    return a = b;    //返回2,为a赋值b,即a为2

    '==': 判断值是否相同,不判断类型

    var a = 1,
        b = '1';
    return a == b;    //返回true

    '===': 精确判断,不仅判断值还判断类型

    var a = 1,
        b = '1';
    return a === b;    //返回false

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

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

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

    2、对于Array,Object等高级类型,==和===是没有区别的进行“指针地址”比较

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

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

    • 因为类型不同,===结果为false

    回复
    0
  • 学习ing

    学习ing2017-06-30 10:00:46

    =是赋值运算符

    let a=b // 将值b赋给变量a

    == 和===是比较运算符

    a == b 比较a与b值是否相等
    a === b 比较a与b是否全等,值和类型都要相同

    回复
    0
  • 欧阳克

    欧阳克2017-06-30 10:00:46

    ==会进行隐式数据类型转换,===不会,就是比较两侧是否真的相等
    http://www.softwhy.com/articl...

    回复
    0
  • 仅有的幸福

    仅有的幸福2017-06-30 10:00:46

    1. “=”用来赋值,直接赋值。

    2. "=="运算符,会先转换,在运算。

    3. "==="绝对相等,两边的值和类型都相等才相等。

    回复
    0
  • 巴扎黑

    巴扎黑2017-06-30 10:00:46

    尽量多用=== ==很容易出问题

    回复
    0
  • 取消回复