JavaScript中的数组 (一)

在JavaScript语言中,数组是一种特殊的对象。 可以这么理解,数组就是属性名是整数的对象,当然其中是有一些不同的:比如数组元素的访问比常规的对象属性要快的多,再比如每个数组都有length 属性 它会随着数组的长度自动变化等等。

  • 数组的声明

  • 使用中括号声明数组是最简单的方式,将其中的元素隔开即可。

  • 使用构造函数 Array.
    var a=new Array(); var a=[];
    上面两个语句本质上是一样的。

    当构造函数Array 只有一个数值参数的时候,相当于创建了该长度的数组。
    var a=new Array(3); console.log(a); // [undefined × 3]
    当我用chrome 执行上面代码的时候 ,他打印了 [undefined × 3],其实会给大家造成误解。其实这个时候它里面是没有元素的。 它不等同于[undefined,undefined,undefined],其实它相当于 [,,,] 。
    var a=new Array(4); var b=[,,,,] var c=[undefined ,undefined ,undefined ,undefined ] console.log(a.map((elem,index)=>index)); // [undefined × 4] console.log(b.map((elem,index)=>index)); // [undefined × 4] console.log(c.map((elem,index)=>index)); //[0,1,2,3]
    大家可以想一想上面的代码输出是为什么,之后会做出解释。

  • 数组的访问
    数组的访问与其他语言一样,使用 [ ] 来访问数组中的每个元素。之前提到过,数组是一种特殊的对象。
    var o={}; o[1]=1; var a=[]; a[1]=1;
    如上,数组和对象都可以通过这种方式来访问元素。区别在于<em>当属性名为小于232的非负整数时,数组会维护一个length的属性</em>
    console.log(o.length); // undefined console.log(a.length); // 2 (数组从0开始)
    所以在js中,数组是没有越界的概念的;如果要查询的元素不存在,和对象一样,会返回undefined。

  • length 属性
    通常来说,大部分情况下我们是不需要手动维护length属性的。数组有两种特殊行为:

  • 为数组的元素赋值,当该元素的索引 index 大于等于length 的时候,length=index+1;

  • 当设置length 为小于当前数组长度的非负整数n时,数组中索引大于等于n的元素将被删除

  • 添加和删除
    除了最简单的为新索引赋值的添加方法,js中预先定义了需要添加和删除的数组方法。 将在下一节进行详细的说明。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Javascript有很多数组的方法,有的人有W3C的API,还可以去MDN上去找,但是我觉得API上说的不全,M...
    顽皮的雪狐七七阅读 4,259评论 0 6
  • 如何控制alert中的换行?\n alert(“p\np”); 请编写一个JavaScript函数 parseQu...
    heyunqiang99阅读 1,104评论 0 6
  • 创建数组及修改 类型检测 转换方法 Array栈操作 Array队列操作 Array的反转和排序 数组的连接与截取...
    togeek阅读 393评论 0 2
  • 数组 在程序语言中数组的重要性不言而喻,JavaScript中数组也是最常使用的对象之一,数组是值的有序集合,由于...
    南山码农阅读 211评论 0 0
  • 今天听到多年的一个闺蜜说几年前暗恋了很久的一个男生反过来追她了,我问她你怎么看的,她说没感觉了。毕竟在她最喜欢那个...
    allday丶阅读 357评论 1 1