js中细小点

Posted lilala-world

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js中细小点相关的知识,希望对你有一定的参考价值。

昨天在写前端代码的时候,遇到一个神奇的问题,我判断序号 num 和数组 arr 的 length 是否相等,如果相等则做想要的处理,伪码如下;

if (num === arr.length) 
  function A();

结果发现,function A() 不会被执行 ,通过打印 num 和 arr.length,发现这两个的值的变化和预期是一致的,那也就是说,无论 num 和 arr.length 如何变化,"num === arr.length"条件均不成立。

百思不得其解之余,找大神求助了,大神看了一眼说:“把你的三等改成双等试试”,ln内心OS:“这能有用就神了~~”,完了刷新一看,预期的效果还真的出来了(好吧,大型真香现场)。

作为一个杠精,我当然是需要追根究底这是为啥啦(纯属闲的,bug还要不要改了!!)~~

翻了下,强大的某乎大神说:

1、对于string,number 等基础类型,== 和 === 是有区别的
1)不同类型间比较,== 只比较“转化成同一类型后的值”看“值”是否相等,=== 是如果类型不同,其结果就是不等
2)同类型比较,直接进行“值”比较,两者结果一样

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

3、基础类型与高级类型,== 和 === 是有区别的
1)对于 ==,将高级转化为基础类型,进行“值”比较
2)因为类型不同,=== 结果为false

那么问题来了,通过打印结果,可以知道我的变量类型是一致的。

alert("num:" + typeof (this.skus[0].num));
      
alert("length:" + typeof (this.skuList.length));

技术图片

技术图片

那么为何用“===”的结果出不来呢?这个问题未知,待有时间再研究下,要继续写代码了~~

以上是关于js中细小点的主要内容,如果未能解决你的问题,请参考以下文章

js常用代码片段(更新中)

Chrome-Devtools代码片段中的多个JS库

Node.js JavaScript 片段中的跳过代码

js简洁代码片段

js 常用代码片段

回归 | js实用代码片段的封装与总结(持续更新中...)