大纲
JS中数组字符串索引和数值索引
首先明确JS中数组的length=最大索引+1,工作发现数组索引居然还能字符串,找到了一篇写的特别好的文章记录一下
JS中数组字符串索引和数值索引研究
总结
- Javascript的数组其实不像PHP或者其他一些语言一样拥有真正的字符串下标,当我们试图为一个js数组添加字符串下标的时候,其实就相当于为该数组对象添加了一个属性,属性名称就是我们所谓的“字符串下标”。由于为数组对象添加属性不会影响到同为该对象属性的length的值,因此length将始终为零。同样地,.pop()和.shift()等作用于数组元素的方法也不能够作用于这些对象属性。因此,如果要使用的是一个完全由“字符串下标”组成的数组,那还是将其声明为一个Object类型的对象要更好一些。
- Javascript数组下标值的范围为0到2的32次方。对于任意给定的数字下标值,如果不在此范围内,js会将它转换为一个字符串,并将该下标对应的值作为该数组对象的一个属性值而不是数组元素,例如array[-1] = “yes” 其实就相当于给array对象添加了一个名为-1的属性,属性值为yes。
如果该下标值在合法范围内,则无论该下标值是数字还是数字字符串,都一律会被转化为数字使用,即 array[“100”] = 0 和 array[100] = 0 执行的是相同的操作。同理也会影响长度。隐式类型转换
let h=[];
h['100']=1;
console.log(h);
console.log(h.length);
console.log(h['100']);
console.log(h[100]);
JS里的undefined
这个真的很绕口
console.log(Boolean(undefined));
console.log(Boolean(null));
console.log(undefined==false);
console.log(null==false);
就很无语,你转换成Boolean是false,你==判断不就是转换同一类型再比较值吗,怎么就!=了???
但是为什么这样我是没整明白
undefined与null
undefined==null
undefined!==null(一个type undefined,一个type object)
undefined,null与false,true
console.log(undefined!=true);
console.log(undefined!=false);
console.log(undefined!==true);
console.log(undefined!==false);
console.log(null!=false);
console.log(null!=true);
console.log(null!==false);
console.log(null!==true