我本来对他们的印象只是,‘!==’和‘===’属于严格不等于,严格等于,另两个就是不严格呗。
后来有一天,我们后端领导帮我看程序,然后在一处条件语句那儿,写的非等于,“!=”是这个,我接手代码以后,悄摸改成了“!==”,后来他问我,有什么区别吗?
我当时没说个所以然,只是说了句习惯。
后来我查了一下,其实是js的一个隐式转换,根本是因为js在定义变量的时候,并没有为其限定数据类型,在使用过程中是存在变化的。
这里只展示一下简单的测试代码,后面跟着输出结果。
严格等于和严格不等于,是不会去改变数据类型的,而弱一点的,存在数据的隐式转换。 如下面字符串1和数字1比较输出结果在两种不同的等于号下,结果是不一样的。
还有一些其他的,可自行测试。
console.log('1' === 1) // false
console.log('1' == 1) // true
console.log('1' !== 1) // true
console.log('1' != 1) // false
console.log([] === '') // false
console.log([] == '') // true
console.log([] == true) // false
console.log(false == 0) // true
console.log(false === 0) // false
console.log(true === 1) // false
console.log(['1', '2'] === '1,2') // false
console.log(['1', '2'] == '1,2') // true
这里挂一个链接,是我在搜隐式转换的时候看见的,还不错,数据转换类型讲得挺细致的,可以看看,而且有代码有输出结果。
https://www.cnblogs.com/ihboy/p/6700059.html
最后
以上就是风中花卷最近收集整理的关于‘==’和‘===’,‘!=’和‘!==’到底有什么不一样?的全部内容,更多相关‘==’和‘===’,‘内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复