JS中相等(==)和等全(===)的区别与练习

简介: JS中相等(==)和等全(===)的区别与练习

JS中相等()和等全(=)的区别与练习

简介

  • 简介
    相等()与全等(=)的主要区别是,会进行类型转换,然后=不会进行类型转换,需要内容和类型都相等,才会返回true。

案例

* 案例一

6 == 6; true

6 === 6; true

6 == “6”; true // 这里会进行强制类型转换 使得这个“6”转换成数字6

6 === “6”; false // 左右两边的类型不同 所以不相等

* 案例二

在js里面,true是bool类型,true可以转换成整形的1,false转换成整形的0。

true == 1; true // 这里true通过类型转换可以转换成整型的1

false == 0; true

true === 1; false // 这里为false是因为两边类型不同

false === 0; false

* 案例三

对于一个字符串如果里面什么都没用,或者内容都是空格,那么强制转换之后就是整型的0了。

null与undefined都是假值所以相等,区别是null代表这个位置不应该有值或者为空值,undefined指的是未声明的变量或者没用赋值的变量。

‘’ == 0; true

’ ’ == 0; true

null == undefined; true

null == 0; false // null是空值 空值不是0

undefined == ‘’; false // undefined是未定义, ‘’是已经定义了的一个空字符串

* 案例四

‘false’ == false; false // false强转之后为0 不等于左边的字符串

// 对于NaN代表的是一个范围的意思,一个不是Number的类型中的任意一个,所以

// 它自身不会与自身相等,所以更不会与别的类型相等

NaN == NaN; false

NaN == NaN; false

NaN === false; false

* 案例五

var a = {};

var b = {};

var c = a;

a == b; false

a === b; false

a == c; true

a === c; true

首先是a和b都是保存在栈里面的内存地址,他们在栈里面定义的地方是不相同的,所以为false,他们的内容存储在堆里面,所以 a==c为true,他们的内容是相等的,c和a指向的是同一块堆上面的内存对象。

相关文章
|
8月前
|
JavaScript 前端开发 容器
this、self、window、top 在 JavaScript 中的区别深入研究
在 JavaScript 开发中,`this`、`self`、`window` 和 `top` 是四个常用的概念。`this` 指向当前执行上下文的对象,其值取决于函数调用方式;`self` 在全局作用域中等同于 `window`,常用于 Web Workers;`window` 代表浏览器窗口,是全局变量的容器;`top` 指向最顶层窗口,用于判断是否在框架中。理解这些概念有助于编写健壮的代码。
240 1
this、self、window、top 在 JavaScript 中的区别深入研究
|
6月前
|
移动开发 运维 供应链
通过array.some()实现权限检查、表单验证、库存管理、内容审查和数据处理;js数组元素检查的方法,some()的使用详解,array.some与array.every的区别(附实际应用代码)
array.some()可以用来权限检查、表单验证、库存管理、内容审查和数据处理等数据校验工作,核心在于利用其短路机制,速度更快,节约性能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
6月前
|
供应链 JavaScript 前端开发
通过array.every()实现数据验证、权限检查和一致性检查;js数组元素检查的方法,every()的使用详解,array.some与array.every的区别(附实际应用代码)
array.every()可以用来数据验证、权限检查、一致性检查等数据校验工作,核心在于利用其短路机制,速度更快,节约性能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
JavaScript 前端开发 索引
js的循环中foreach、for in和for of的区别
js的循环中foreach、for in和for of的区别
469 0
|
前端开发 JavaScript UED
JavaScript防抖和节流的使用及区别
JavaScript防抖和节流的使用及区别
307 57
|
10月前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
165 1
|
10月前
|
设计模式 JavaScript 前端开发
js中new和object.creat区别
【10月更文挑战第29天】`new` 关键字和 `Object.create()` 方法在创建对象的方式、原型链继承、属性初始化以及适用场景等方面都存在差异。在实际开发中,需要根据具体的需求和设计模式来选择合适的方法来创建对象。
|
11月前
|
存储 JavaScript 前端开发
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
JavaScript 数据类型分为基本数据类型和引用数据类型。基本数据类型(如 string、number 等)具有不可变性,按值访问,存储在栈内存中。引用数据类型(如 Object、Array 等)存储在堆内存中,按引用访问,值是可变的。本文深入探讨了这两种数据类型的特性、存储方式、以及检测数据类型的两种常用方法——typeof 和 instanceof,帮助开发者更好地理解 JavaScript 内存模型和类型检测机制。
382 0
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
|
11月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
200 2