数组的数字和非数字下标的区别

数组下标使用字符串,控制台输入代码

var array = [];
 array["a"] = "hello";
array["b"] = "world";
array["c"] = "yes";
console.log("length: " + array.length);

控制台输出

 

 此基础上输出

 

 证明之前的操作是成功的,那么既然数组的下标可以是字符串,为什么插入元素之后数组的长度显示仍然为零呢?

尝试给array[“10”]赋值,此时数组的长度变为11

控制台输出完整的数组array,可以看到输出结果与对象类似

我们知道Array对象是从Object对象继承得到的,难道这些“看不见”的“数组元素”都变成了当前这个Array实例对象的属性?

Javascript的数组其实不像PHP或者其他一些语言一样拥有真正的字符串下标,当我们试图为一个js数组添加字符串下标的时候,其实就相当于为该数组对象添加了一个属性,属性名称就是我们所谓的“字符串下标”。由于为数组对象添加属性不会影响到同为该对象属性的length的值,因此该值将始终为零。同样地,.pop()和.shift()等作用于数组元素的方法也不能够作用于这些对象属性。因此,如果要使用的是一个完全由“字符串下标”组成的数组,那还是将其声明为一个Object类型的对象要更好一些。

从别人文章里面找到的例子https://stackoverflow.com/questions/10326635/string-index-in-js-array

然而array["10"]="ma"将数组的长度改为了11?

Javascript数组下标值的范围为0到2的32次方。对于任意给定的数字下标值,如果不在此范围内,js会将它转换为一个字符串,并将该下标对应的值作为该数组对象的一个属性值而不是数组元素,例如array[-1] = "yes" 其实就相当于给array对象添加了一个名为-1的属性,属性值为yes。如果该下标值在合法范围内,则无论该下标值是数字还是数字字符串,都一律会被转化为数字使用,即 array["100"] = 0 和 array[100] = 0 执行的是相同的操作。 

补充

 

索引数组和关联数组的区别

1. 索引数组

就是数组的下标是数字其实这是关联数组的简写方式

举个例子

arr[0] 其实他是arr[“0”] 的简写方式,所以索引数组的本质上是关联数组

2.关联数组

关联数组的定义就是数组里面的下标为字符串,例如arr[“index”] 可以简写为arr.index。

而arr[“0”]不简写为arr.0,有一个很重要的原因就是 和js里面的小数冲突了 所以简写方式用[]代替

posted @ 2020-12-21 17:13  Viola_left  阅读(754)  评论(0编辑  收藏  举报