Array类型

除了Object之外,Array类型在ECMAScript中也很常用。ECMAScript中的数组与其他多数语言中的数组有着相当大的区别。ECMAScript数组的每一项可以保存任何类型的数据。也就是说,可以用数组第一个位置来保存字符串,用第二位置来保存数值,用第三位置来保存对象,以此类推。而且ECMAScript数组的大小是可以动态调整的,即可以随着数据添加自动增长以容纳新增数据。

语法

创建数组的基本方式有两种。第一种是使用Array构造函数,代码如下

var colors=new Array();

如果预先知道数组要保存的项目数量,也可以给构造函数传递该数组,而且该数值会自动变成length属性的值。例如,下面的代码将创建length值为20的数组

var colors=new Array(20);

也可以向Array构造函数传递数组中应该包括的项。

//以下代码创建了一个包括三个字符串值得数组
var colors=new Array("red","blue","pink")

给构造函数传递一个值也可以创建数组,如果传递的是数值,那么就会创建length为这个数值的数组,如果传递的是其他类型的参数,则会创建包含那个值的只有一项的数组。例子如下

var colors=new Array(3);        //创建一个包含3项的数组
var names=new Array("breeze"); //创建一个包含1项,即字符串"breeze"的数组

另外,在使用Array构造函数时也可以省略new操作符,如下

var colors=Array(3);
var names=Array("breeze");

创建数组的第二种基本方法是使用数组字面量表司法。数组字面量由一对包括数组项的方括号表示,多个数组项之间以逗号隔开,如下所示

var colors=["red","blue","green"];
var names=[];

读取和修改

使用方括号并提供响应值的基于0的数字索引,如下所示:

var colors=["red","blue","green"];
alert(colors[0]); //"red"
colors[2]="black"; //修改第三项
colors[3]="white"; //增加第四项

方括号中的索引表示要访问的值。如果索引小于数组中的项数,则返回对应项的值,所以colors[0]会返回"red"。设置数组的值也使用同样的语法,但会替换原来的值。如果索引数超过数组长度,则是新增。

数组的length属性

数组的项数保存在length属性中,这个属性始终会返回0或更大的值,如下面这个例子所示:

var colors=["red","blue","pink];  //创建一个包括3个字符串的数组
var names=[]; //创建一个空数组 alert(colors.length); //3
alert(names.length); //0

数组的length属性很有特点—— 它不是只读的。因此,通过设置这个属性,我们可以从数组的末尾移除或向数组中添加新项。请看下例

var colors=["red","blue","pink"];      //创建一个包括3个字符串的数组
colors.length=2;
alert(colors[2]); //undefined

这个例子中的数组colors一开始有三个值。将其length属性设置为2会移除最后一项,结果再访问colors[2]就会显示undefined了。如果将length属性设置为大于数组项数的值,则新增的每一项都会取得undefined,如下

var colors=["red","blue","pink"];      //创建一个包括3个字符串的数组
colors.length=4;
alert(colors[3]); //undefined

虽然colors数组包括3个项,但把它的length属性设置成了4。这数组不存在位置3,所以访问这个位置的值就得到了特殊值undefined。

利用length属性也可以在数组末尾添加新项,如下

var colors=["red","blue","pink"];
colors[colors.length]="black"; //在位置3添加新项
colors[colors.length]="white"; //在位置4添加新项

原理:由于数组的最后一项的索引都是length-1,因此新项的下一个位置都是length这个值。

当把一个值放在超出当前数组大小的位置上时,数组就会重新计算长度,即长度值等于最后一项的索引加1,如下

var colors=["red","blue","pink"];
colors[99]="black";
alert(colors.length); //100

在这个例子中,我们向colors数组的位置99插入了一个值,结果数组新长度length就是100(99+1)。而位置3到位置98实际上都是不存在的所以我们访问它们都将返回undefined

引用类型之Array(一)的更多相关文章

  1. JavaScript高级编程——引用类型、Array数组使用、栈方法

    JavaScript高级编程——引用类型.Array数组使用.栈方法 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999 ...

  2. JavaScript引用类型之Array类型一

    一.简介 除了Object之外,Array类型恐怕是ECMAScript中最常用的类型了.下面就来分析ECMAScript中的数组与其他语言中的数组的异同性: 1.相同点: (1)他们都是数据的有序列 ...

  3. 引用类型之Array类型

    Array类型 ECMAScript数组与其它语言数组一样,都是数据的有序列表.但是ECMAScript数组的每一项可以保存任何类型的数据.而且,ECMAScript数组是可以动态调整的. 1.创建和 ...

  4. JavaScript引用类型之Array数组之强大的splice()方法

    splice()方法可以说是Array数组最强大的方法,他的用法很多,主要用法是向数组的中部插入项! 下面是它的用法: arrayObject.splice(index,howmany,element ...

  5. JavaScript引用类型之Array数组的排序方法

    数组中已经存在两个JavaScript给我们定义好的重排序的方法:reverse()和sort()方法,下面来简单分析下: 1.reverse()    用于反转数组项的顺序,代码如下: <sc ...

  6. JavaScript引用类型之Array数组的栈方法与队列方法

    一.栈方法 ECMAScript数组也提供了一种让数组的行为类似与其他数据结构的方法.具体的来说,数组可以变现的向栈一样,栈就是一种可以限制插入和删除向的数据结构.栈是一种LIFO(Last In F ...

  7. JavaScript引用类型之Array数组的toString()和valueof()方法的区别

    一.转换方法 1.在JavaScript中几乎所有对象都具有toLocaleString().toString和valueof()方法,因为,所有的对象都继承自Object,而前面所说的方法都是Obj ...

  8. JavaScript引用类型之Array类型API详解

    Array类型也是ECMASCRIPT中最常见的数据类型,而且数据的每一项可以保存任何类型的数值,而且数组的大小是可以动态调整的,可以随着数据的添加自动增长以容纳新的数据.下面,总结数据的一些常用方法 ...

  9. 初心不负 笔记-JS高级程序设计-引用类型篇-Array

    ES3方法集合: 1join()方法,将一个数组里面的所有元素转换成字符串,然后再将他们连接起来返回一个字符串,通过制定的符号,默认值为逗号.不会改变原数组 ,,,,]; a.join(); &quo ...

  10. JS引用类型之Array

    ECMAScript中的数组可以说是比较神奇了, ECMAScript中定义的数组每一项可以保存不同的数据类型,如第一项为字符串,第二项为数值等等 1. 那怎么创建一个数组呢? 方法和创建对象实例类似 ...

随机推荐

  1. WPF管理系统开发框架搭建指南,2020从入门到放弃

    WPF技术是一个很不错的技术,但一直没有上手过正式的项目,趁在做这个医疗项目时,遂搭建一个WPF开发框架,目的是为了统一WPF开发并提高开发效率:我对WPF技术算是零基础,现学现卖,用这些不成体系的文 ...

  2. JVM 垃圾收集算法 标记-清楚、标记-复制、标记-整理

    摘要 Java程序在运行过程中会产生大量的对象,但是内存大小是有限的,如果光用而不释放,那内存迟早被耗尽.如C.C++程序,需要程序员手动释放内存,Java则不需要,是由垃圾回收器去自动回收. 垃圾回 ...

  3. 善用Bash history 命令

    大家好,我是良许 相信大家平时都有用 history 命令来查看命令历史记录,但是实际上 history 命令并非只有这个功能,history 还有很多有用的功能.尤其是 Bash 版本的 histo ...

  4. java最简单的知识之创建一个简单的windows窗口,利用Frame类

    作者:程序员小冰,CSDN博客:http://blog.csdn.net/qq_21376985 QQ986945193 微博:http://weibo.com/mcxiaobing 首先给大家看一下 ...

  5. 如何安装CRX格式?Chrome插件离线安装,CRX格式安装方法 JSON-handle Chrome插件下载

    目前,Chrome官方已经禁止非Chrome商店的应用安装了,所以本站的应用还是通过国外服务器从谷歌官方应用市场下载下来的,提供给国内的广大用户使用,下面我们就以 Check my cookies 插 ...

  6. 最通俗易懂的 Redis 架构模式详解

    前言 话说有一名意大利程序员,在 2004 年到 2006 年间主要做嵌入式工作,之后接触了 Web,2007 年和朋友共同创建了一个网站,并为了解决这个网站的负载问题(为了避免 MySQL 的低性能 ...

  7. leetcode刷题-88.合并两个有序数组

    题目 给你两个有序整数数组 nums1 和 nums2,请你将 nums2 合并到 nums1 中,使 nums1 成为一个有序数组. 说明: 初始化 nums1 和 nums2 的元素数量分别为 m ...

  8. 解决 Mac 上 Docker 无法直接 ping 通的问题

    解决 Mac 上 Docker 无法直接 ping 通的问题 原文连接 一.背景 Mac os Mojave 10.14.3 Docker Desktop community 2.3.0.4 二.问题 ...

  9. Navicat Premium 15.0.17 破解激活(DFoX 注册机)

    Navicat Premium v15.0.17 安装程序和注册机已放入百度网盘,下载地址在本文最后 1. 下载并安装 Navicat Premium 15 在官网下载 Windows 版本的 Nav ...

  10. ASP.NET Core 性能优化最佳实践

    本文提供了 ASP.NET Core 的性能最佳实践指南. 译文原文地址:https://docs.microsoft.com/en-us/aspnet/core/performance/perfor ...