JavaScript中怎么理解=、==和===
迷茫
迷茫 2017-06-30 09:58:46
0
6
1005

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

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(6)
大家讲道理

= : 赋值操作

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

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

我想大声告诉你

'=': 表示赋值,

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

学习ing

=是赋值运算符

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

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

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

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

仅有的幸福
  1. “=”用来赋值,直接赋值。

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

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

巴扎黑

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板