首页 > 代码库 > JavaScript的赋值深坑
JavaScript的赋值深坑
以前学C++的时候(大学时代),对传参时印象深刻的是,传的值是值还是值的地址.
之后学JavaScript的时候,发现不用理会那么多,虽然不严谨,但是用起来很便捷,比如说类型转换呀,啥的简单多了.....
可是最近几天就遇到了坑...
先上代码:
[]===[] // false []==[] // false
上面的代码是用来判断是否为空数组用的.不巧的是,结果如大家看到的,起初我以为是JavaScript的bug,也就不以为然.因为JavaScript的坑还是挺多了,而且之前也有大概的例子,如下:
表达式 | 值 |
---|---|
null == undefined | true |
"NaN" == NaN | false |
5 == NaN | false |
NaN == NaN | false |
NaN != NaN | true |
false == 0 | true |
true == 1 | true |
true == 2 | false |
undefined == 0 | false |
null == 0 | false |
"5" == 5 | true |
所以,也就没有多放在心上.....大胆的继续前行去了~~
可是最近又遇到了一个问题,是创建二维数组的时候:
!function matrixAddition() { var temAry = [], newAry = [], i, j; for (i = 3; i--;) { for (j = 2; j--;) { temAry[j] = i + j; } newAry.push(temAry); // temAry =[]; console.log("tem : "+temAry); console.log("new : "+newAry.join(",")); } return newAry; }(); 结果是 tem : 2,3 new : 2,3 tem : 1,2 new : 1,2,1,2 tem : 0,1 new : 0,1,0,1,0,1 如果把注释去掉后,结果就正常了 正确的结果 tem : new : 2,3 tem : new : 2,3,1,2 tem : new : 2,3,1,2,0,1
为啥把temAry赋值空就没事了...而且这里也不存在闭包作用域的影响..
答案是:
其实赋值的时候,并不是赋值,而是赋了地址,原因是array是一个对象.
首先JavaScript中有5种简单数据类型(也称为基本数据类型):Undefined、Null、Boolean、Number和String。还有1种复杂数据类型——Object,Object本质上是由一组无序的名值对组成的.
但用简单类型赋值的时候的确给的是值,而在用其他类型赋值的时候,则是给地址.
这也就顺利成章的说明了 为什么[]==[].
题外话:果然我基础还是不扎实,决定从新看一遍<<JavaScript高级编程>>去,最近弄node太多了,JavaScript都落下了~
JavaScript的赋值深坑
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。