您的位置:首页技术文章
文章详情页

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

【字号: 日期:2023-04-19 10:24:10浏览:57作者:猪猪

问题描述

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

问题解答

回答1:

= : 赋值操作

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

1 == ’1’; // true1 == true; // true0 == false; // true

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

1 === ’1’; // false1 === true; // false0 === false; // false

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

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

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

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

进行“指针地址”比较

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

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

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

回答2:

’=’: 表示赋值,

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

回答3:

=是赋值运算符

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

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

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

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

回答5:

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

'=='运算符,会先转换,在运算。

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

回答6:

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

标签: JavaScript
相关文章: