引用类型之Array(一)
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(一)的更多相关文章
- JavaScript高级编程——引用类型、Array数组使用、栈方法
JavaScript高级编程——引用类型.Array数组使用.栈方法 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999 ...
- JavaScript引用类型之Array类型一
一.简介 除了Object之外,Array类型恐怕是ECMAScript中最常用的类型了.下面就来分析ECMAScript中的数组与其他语言中的数组的异同性: 1.相同点: (1)他们都是数据的有序列 ...
- 引用类型之Array类型
Array类型 ECMAScript数组与其它语言数组一样,都是数据的有序列表.但是ECMAScript数组的每一项可以保存任何类型的数据.而且,ECMAScript数组是可以动态调整的. 1.创建和 ...
- JavaScript引用类型之Array数组之强大的splice()方法
splice()方法可以说是Array数组最强大的方法,他的用法很多,主要用法是向数组的中部插入项! 下面是它的用法: arrayObject.splice(index,howmany,element ...
- JavaScript引用类型之Array数组的排序方法
数组中已经存在两个JavaScript给我们定义好的重排序的方法:reverse()和sort()方法,下面来简单分析下: 1.reverse() 用于反转数组项的顺序,代码如下: <sc ...
- JavaScript引用类型之Array数组的栈方法与队列方法
一.栈方法 ECMAScript数组也提供了一种让数组的行为类似与其他数据结构的方法.具体的来说,数组可以变现的向栈一样,栈就是一种可以限制插入和删除向的数据结构.栈是一种LIFO(Last In F ...
- JavaScript引用类型之Array数组的toString()和valueof()方法的区别
一.转换方法 1.在JavaScript中几乎所有对象都具有toLocaleString().toString和valueof()方法,因为,所有的对象都继承自Object,而前面所说的方法都是Obj ...
- JavaScript引用类型之Array类型API详解
Array类型也是ECMASCRIPT中最常见的数据类型,而且数据的每一项可以保存任何类型的数值,而且数组的大小是可以动态调整的,可以随着数据的添加自动增长以容纳新的数据.下面,总结数据的一些常用方法 ...
- 初心不负 笔记-JS高级程序设计-引用类型篇-Array
ES3方法集合: 1join()方法,将一个数组里面的所有元素转换成字符串,然后再将他们连接起来返回一个字符串,通过制定的符号,默认值为逗号.不会改变原数组 ,,,,]; a.join(); &quo ...
- JS引用类型之Array
ECMAScript中的数组可以说是比较神奇了, ECMAScript中定义的数组每一项可以保存不同的数据类型,如第一项为字符串,第二项为数值等等 1. 那怎么创建一个数组呢? 方法和创建对象实例类似 ...
随机推荐
- 树(Tree)解题总结
定义 树是一种抽象数据类型(ADT)或是实现这种抽象数据类型的数据结构,用来模拟具有树状结构性质的数据集合.它是由 n(n>0) 个有限节点组成一个具有层次关系的集合.. 二叉搜索树(Binar ...
- Java学习笔记——java基础
2020.9.1 学习来自 https://www.liaoxuefeng.com/wiki/1252599548343744/1255883729079552 一.变量和数据类型 基本数据类型 基本 ...
- python给excel文件加密码,并重新生成文件
需安装pywin32 pip install pywin32 直接上源码.简单几行就搞定 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手. ...
- Labview学习之路(四)公式和公式节点
在labview里边,有公式和公式节点两个控件都可以实现表达复杂表达式的功能 公式 位置: 程序框图---编程---Express---算数与比较---公式 用法: 点开后是这个样子 可以任意添加输出 ...
- android开发之动画的详解 整理资料 Android开发程序小冰整理
/** * 作者:David Zheng on 2015/11/7 15:38 * * 网站:http://www.93sec.cc * * 微博:http://weibo.com/mcxiaob ...
- 【学习中】Unity插件之NGUI 完整视频教程
课程 章节 内容 签到 Unity插件之NGUI 完整视频教程 第一章 NGUI基础控件和基础功能学习 1.NGUI介绍和插件的导入 6月29日 2.创建UIRoot 6月29日 3.学习Label控 ...
- springboot2.x基础教程:Swagger详解给你的接口加上文档说明
相信无论是前端还是后端开发,都或多或少地被接口文档折磨过.前端经常抱怨后端给的接口文档与实际情况不一致.后端又觉得编写及维护接口文档会耗费不少精力,经常来不及更新.其实无论是前端调用后端,还是后端调用 ...
- 简介&目录
欢迎来到 MK 的博客鸭~ 这里会被我用来发一些OI算法.数据结构的学习笔记,各种游记和其他的一些内容,希望大家多多关照! ε≡٩(๑>₃<)۶ 然后目录就也放这里⑧:
- Mybatis源码学习第七天(插件开发原理)
插件概述: 插件是用来改变或者扩展mybatis的原有功能,mybatis的插件就是通过继承Interceptor拦截器实现的,在没有完全理解插件之前j禁止使用插件对mybatis进行扩展,有可能会导 ...
- DSRC和USRP的购买调研
(转移自旧博客) 11.29 2019 实验室采购,所以进行了一定程度的调研. 主要包括两个Part,分别是DSRC和USRP的简单总结,购买建议和详细资料. Part.1 DSRC调研总结 1.1 ...