JavaScript中的Array对象就是数组,首先是一个动态数组,无需预先制定大小,而且是一个像Java中数组、ArrayList、Hashtable等的超强综合体。

一、数组的声明

  常规方式声明:

    1、var arrName = new Array();//创建一个数组

    2、var arrName = new Array([size]); //创建一个数组并指定长度,注意不是上限,是长度

    3、var arrName =new Array("孤傲苍狼","白虎神皇","灭世魔尊");//创建一个数组,并初始化数组的内容

  注意:虽然var arrName = new Array([size]);指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为2,仍然可以将元素存储在规定长度以外的,注意:这时长度会随之改变。

  Array的简化声明

    1、普通数组初始化:var arr = [3, 5, 6, 8, 9];

范例1:

 1 <script type="text/javascript">
2 //JavaScript声明数组的四种方式
3 var arr1 = new Array();//创建一个空数组
4 arr1[0]="xdp";
5 arr1[1]="gacl";
6 var arr2 = new Array(2);//创建一个数组并指定长度为2
7 arr2["name0"]="xdp";//arr2第一个元素
8 arr2["name1"]="gacl";//arr2第二个元素
9 arr2["name2"]="xtxd";//arr2第三个元素,arr2虽然在声明时指明了长度为2,但是还是可以添加超过其指明长度的元素
10 var arr3 = new Array("孤傲苍狼","白虎神皇","灭世魔尊");//创建一个数组并初始化数组中的元素
11 var arr4 = [1,true,"String"];//Array的简化声明
12
13 document.write("遍历arr1中的元素:<br/>");
14 for(var i in arr1) {
15 document.write(arr1[i]+"<br/>");
16 }
17 document.write("-----------------------------------------------------------------------------<br/>");
18 document.write("遍历arr2中的元素:<br/>");
19 for(var i in arr2) {
20 document.write("arr2[\""+i+"\"]="+arr2[i]+"<br/>");
21 }
22 document.write("-----------------------------------------------------------------------------<br/>");
23 document.write("遍历arr3中的元素:<br/>");
24 for(var i in arr3) {
25 document.write(arr3[i]+"<br/>");
26 }
27 document.write("-----------------------------------------------------------------------------<br/>");
28 document.write("遍历arr4中的元素:<br/>");
29 for(var i in arr4) {
30 document.write(arr4[i]+"<br/>");
31 }
32 </script>

运行结果:

  

范例2:

 1 <script type="text/javascript">
2 var names = new Array();//普通方式声明数组,不需要指明数组的长度
3 names[0] = "孤傲苍狼";
4 names[1] = "白虎神皇";
5 names[2] = "灭世魔尊";
6 for (var i = 0; i < names.length; i++) {
7 document.write("names["+i+"] = "+names[i]);
8 document.write("<br/>");
9 }
10
11 var pinyins = new Array();
12 pinyins["人"] = "ren";
13 pinyins["口"] = "kou";
14 pinyins["手"] = "shou";
15 document.write("pinyins[\"人\"] = "+pinyins["人"]);
16 document.write("<br/>");
17 document.write("pinyins.手 = "+pinyins.手);//像Hashtable、Dictionary那样用,而且像它们一样效率高。
18 document.write("<br/>");
19 //Array的简化声明
20 var arr1 = [3, 5];//普通数组初始化
21 for (var i = 0; i < arr1.length; i++) {
22 document.write("arr1["+i+"] = "+arr1[i]);
23 document.write("<br/>");
24 }
25 </script>

运行结果:

  

二、数组练习

  Ferris写过一个数组的案例,以下就是他的案例代码,挺全的,思路也挺好!

  1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2 <html xmlns="http://www.w3.org/1999/xhtml"><head>
3 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
4 <title>数组练习:各种数组方法的使用</title>
5 <style>
6 div{color:green;padding:10px 15px;margin:12px 0;background:#f0f0f0;border:1px dotted #333;font:12px/1.5 Courier New;word-wrap:break-word;}
7 </style>
8 <script type="text/javascript">
9 window.onload = function ()
10 {
11 var aDiv = document.getElementsByTagName("div");
12 var aInput = document.getElementsByTagName("input");
13 var i = 0;
14 var bS1 = bS2 = true;
15 var aTmp = [];
16
17 //删除/添加第一项
18 aInput[0].onclick = function ()
19 {
20 aTmp = getArray(aDiv[0].innerHTML);
21 bS1 ?
22 //删除第一项, shift()方法
23 (aTmp.shift(), this.value = this.value.replace("删除","添加"), bS1 = false) :
24 //添加第一项, unshift()方法
25 (aTmp.unshift("January(1)"), this.value = this.value.replace("添加","删除"), bS1 = true);
26 //输出
27 aDiv[0].innerHTML = aTmp.join()
28 };
29
30
31 //删除/添加最后一项
32 aInput[1].onclick = function ()
33 {
34 aTmp = getArray(aDiv[0].innerHTML);
35 bS2 ?
36 //删除最后一项, pop()方法
37 (aTmp.pop(), this.value = this.value.replace("删除","添加"), bS2 = false) :
38 //添加最后一项, push()方法
39 (aTmp.push("December(12)"), this.value = this.value.replace("添加","删除"), bS2 = true);
40 //输出
41 aDiv[0].innerHTML = aTmp.join()
42 };
43
44
45 //复制, concat()方法
46 aInput[2].onclick = function ()
47 {
48 aTmp = getArray(aDiv[1].innerHTML);
49 //输出
50 aDiv[1].innerHTML = aTmp.concat(aTmp).toString().replace(/\s/g,"")
51 };
52
53
54 //还原, 利用数组的 length 特点
55 aInput[3].onclick = function ()
56 {
57 aTmp = getArray(aDiv[1].innerHTML);
58 //设置数组长度
59 aTmp.length = 10;
60 //输出
61 aDiv[1].innerHTML = aTmp.join()
62 };
63
64
65 //第三组数据还原
66 aInput[4].onclick = function ()
67 {
68 aTmp = ["red","green","blue","white","yellow","black","brown"];
69 //输出
70 aDiv[2].innerHTML = aTmp.join()
71 };
72
73
74 //删除前三项
75 aInput[5].onclick = function ()
76 {
77 aTmp = getArray(aDiv[2].innerHTML);
78 //删除, 0开始, 删除3个
79 aTmp.splice(0, 3);
80 //输出
81 aDiv[2].innerHTML = aTmp.join()
82 };
83
84
85 //删除第二至三项
86 aInput[6].onclick = function ()
87 {
88 aTmp = getArray(aDiv[2].innerHTML);
89 //删除, 2开始, 删除2个
90 aTmp.splice(1, 2);
91 //输出
92 aDiv[2].innerHTML = aTmp.join()
93 };
94
95
96 //在第二顶后插入"orange", "purple"
97 aInput[7].onclick = function ()
98 {
99 aTmp = getArray(aDiv[2].innerHTML);
100 //插入, 2开始, 插入"orange", "purple"
101 aTmp.splice(1, 0, "orange", "purple");
102 //输出
103 aDiv[2].innerHTML = aTmp.join()
104 };
105
106
107 //替换第二项和第三项
108 aInput[8].onclick = function ()
109 {
110 aTmp = getArray(aDiv[2].innerHTML);
111 //插入, 2开始替换
112 aTmp.splice(1, 2, "#009900", "#0000ff");
113 //输出
114 aDiv[2].innerHTML = aTmp.join()
115 };
116
117 //将div中的内容转为数组
118 //str div对象
119 function getArray(str)
120 {
121 aTmp.length = 0;
122 str = str.split(",");
123 for (var i in str)aTmp.push(str[i]);
124 return aTmp
125 }
126 }
127 </script>
128 </head>
129 <body>
130 <div>January(1),February(2),March(3),April(4),May(5),June(6),July(7),Aguest(8),September(9),October(10),November(11),December(12)</div>
131 <input value="删除January(1)" type="button">
132 <input value="删除December(12)" type="button">
133 <div>0,1,2,3,4,5,6,7,8,9</div>
134 <input value="复制" type="button">
135 <input value="还原" type="button">
136 <div>red,green,blue,white,yellow,black,brown</div>
137 <input value="还原" type="button">
138 <input value="删除前三项" type="button">
139 <input value="删除第二至三项" type="button">
140 <input value="在第二项后插入(orange, purple)" type="button">
141 <input value="替换第二项和第三项" type="button">
142
143
144 </body></html>

JavaScript学习总结(4)——JavaScript数组的更多相关文章

  1. Javascript学习4 - 对象和数组

    原文:Javascript学习4 - 对象和数组 在Javascript中,对象和数组是两种基本的数据类型,而且它们也是最重要的两种数据类型. 对象是已命名的值的一个集合,而数组是一种特殊对象,它就像 ...

  2. JavaScript学习(1)之JavaScript基础

    JavaScript学习(1)之JavaScript基础 由于工作原因,开发语言逐渐以JavaScript为主,所以,抽空学习了下JavaScript语法.等现阶段的工作稳定之后,陆续会分享下自己在学 ...

  3. 转载——JavaScript学习笔记:取数组中最大值和最小值

    转载自:http://www.w3cplus.com/javascript/calculate-the-max-min-value-from-an-array.html. 取数组中最大值 可以先把思路 ...

  4. Javascript学习笔记1 javascript的特点

    ..对于网页而言,Javascript无处不在,对于英语不好的人它简直是噩梦般的存在,但形式所逼,今天开始着手学习!希望自己能坚持下去.从什么地方着手,我的目标是从大处着眼,从应用着眼,不抠细节,反正 ...

  5. JavaScript学习系列3 -- JavaScript arguments对象学习

    在实际项目开发中,目前还是很少使用到JavaScript 中的arguments对象,那么它到底是干什么用的呢 arguments是JavaScript中的一个类数组对象,它代表传给一个正在执行的函数 ...

  6. Javascript学习笔记3 Javascript与BOM简介

    什么是BOM BOM是browser object model的缩写,简称浏览器对象模型 BOM提供了独立于内容而与浏览器窗口进行交互的对象 由于BOM主要用于管理窗口与窗口之间的通讯,因此其核心对象 ...

  7. JavaScript学习笔记(4)——JavaScript语法之变量

    一.变量可以使用短名称(比如 x 和 y),也可以使用描述性更好的名称(比如 age, sum, totalvolume). 变量必须以字母开头 变量也能以 $ 和 _ 符号开头(不过我们不推荐这么做 ...

  8. JavaScript学习笔记:检测数组方法

    检查数组的方法 很多时候我们需要对JavaScript中数据类型(Function.String.Number.Undefined.Boolean和Object)做判断.在JavaScript中提供了 ...

  9. JavaScript学习总结(八)——JavaScript数组

    JavaScript中的Array对象就是数组,首先是一个动态数组,无需预先制定大小,而且是一个像Java中数组.ArrayList.Hashtable等的超强综合体. 一.数组的声明 常规方式声明: ...

  10. JavaScript学习笔记3之 数组 & arguments(参数对象)& 数字和字符串转换 & innerText/innerHTML & 鼠标事件

    一.Array数组 1.数组初始化(Array属于对象类型) /*关于数组的初始化*/ //1.创建 Array 对象--方法1: var arr1=[]; arr1[0]='aa';//给数组元素赋 ...

随机推荐

  1. Exception: Operation xx of contract xx specifies multiple request body parameters to be serialized without any wrapper elements.

    Operation 'CreateProductCodeStock' of contract 'IChileService' specifies multiple request body param ...

  2. Anatomy of an IIS7 configuration path

    The concept of configuration paths is fundamental to managing and operating an IIS server, so I want ...

  3. html关于不换行代码

    类似这种效果  这是基于a标签 不是用table实现的 <a style="display: inline-block;white-space:nowrap;width: 100px; ...

  4. hight charts

    hight charts http://www.hcharts.cn/resource/index.php http://www.hcharts.cn/api/index.php

  5. Linux 串口终端调试工具minicom

    minicom是一个串口通信工具,就像Windows下的超级终端.可用来与串口设备通信,如调试交换机和Modem等,它的使用完全依靠键盘的操作. 一.安装: Linux各发行版因软件管理方式不同而不同 ...

  6. @Mapper注解在springboot中无法注入

    问题① @Mapper注解报红无法注入 方法 在pom文件中添加依赖

  7. 【福利】微信小程序130个精选Demo合集

    小编最近在开发小程序,也读到了不少优秀的小程序源码,项目中有些需求可以直接从源码里粘贴复制过来,虽然这样做不利于自己独立编写代码,但比较是给公司做项目啊,秉着效率第一的原则,简直没有什么比ctrl+c ...

  8. SSH框架的多表查询(方法二)

     必须声明本文章==>http://www.cnblogs.com/zhu520/p/7773133.html  一:在前一个方法(http://www.cnblogs.com/zhu520/p ...

  9. 使用virtualenv搭建python虚拟开发环境

    在使用python做开发时,如果多人需要在同一台机器上工作,或者机器环境经常变化时, 添加或删除一些python包很可能会影响到你自己的开发环境. 因此,通过virtualenv工具可以创建一个完全属 ...

  10. HDU4009 Transfer water 【最小树形图】

    Transfer water Time Limit: 5000/3000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Others) T ...