`
chengzhi
  • 浏览: 110317 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

js数组的完整说明

阅读更多

使用数组
 基本操作
  <script>
   var a=new Array("cctv","sxtv","tytv");
   var a=new Array(3);
   var a=new Array();
   a[0]="cctv";
   a[1]="sxtv";
   a[2]="tytv";
   a[3]="xzy";
   for(i=0;i<a.length;i++)
   document.writeln(a[i]);
  </script>
 多维数组

<script>
var rows= new Array();
rows[0]=new Array(5);
rows[1]=new Array(5);

rows[0][0]="你好";
rows[0][1]="邢志云";

if(rows[0][0]!=null)
{
 alert(rows[0][0]);
}

</script>

数组赋值

可以像上边那样简单的依次赋值,也可以像下边的这样:
<script>
var xzy=new Array();
xzy=[1,2,3,4,5,"邢志云","嘿嘿"];//给数组xzy赋值
for(var i=0;i<xzy.length;i++)
{
 alert(xzy[i]);
}
</script>
也可以直接赋值成多维数组
<script>
var s=["你好",["中国","太原","邢志云"],[3,3333],[4,4444],[5,5555],["0",["a","b","c"]],"cc"];
//        0               1                   2       3        4             5            6
//                  10    11       12     20  21   30  31    40  41

alert(s);//你好,中国,太原,邢志云,3,3333,4,4444,5,5555
alert(s[1]);//中国,太原,邢志云
alert(s[1][2]);//邢志云
alert(s[2][0]);//3
alert(s[2][1]);//3333
alert(s[5][1][0]);//a
alert(s[5][1][2]);//c
alert(s[6]);//cc
</script>

push:数据可以向最后的追加元素

var arr=new Array()
arr[0]="xbc1";
arr[1]="bcx2";
arr[2]="cctv3";
arr[3]="xctv4";
arr.push("邢志云");//向最后追加,也可以同时push多个
arr.push("0123");
for(i=0;i<arr.length;i++)
{
 if(arr[i]!=null)
 document.writeln(arr[i]);
}

pop:弹出最后一个元素,后进先出

 var arr=new Array();
 var s;
 arr[0]="a1";
 arr[1]="a2";
 arr[2]="a3";
 arr[3]="a4";
 s=arr.pop();//弹出最后一个元素,把值付给s,并删除最后一个元素
 alert(s);
 for(i=0;i<arr.length;i++)
 {
  document.writeln(arr[i]);
 }
 //显示: a1 a2 a3
unshift:插入到第一个之前,

 var arr=new Array();
 var s;
 arr[0]="a1";
 arr[1]="a2";
 arr[2]="a3";
 arr[3]="a4";
 arr.unshift("第一","第二");//插到第一个元素之前,后面的整体后移
 for(i=0;i<arr.length;i++)
 {
  document.write(arr[i]+":");
 }
 //显示: 第一:第二:a1:a2:a3:a4:
 shift:弹出第一个元素,先进先出
 var arr=new Array();
 var s;
 arr[0]="a1";
 arr[1]="a2";
 arr[2]="a3";
 arr[3]="a4";
 s=arr.shift();//弹出第一个元素,把值付给s,并删除第一个元素
 alert(s);
 for(i=0;i<arr.length;i++)
 {
  document.writeln(arr[i]);
 }
 //显示: a2 a3 a4
join:利用数组的join方法,连接所有的数组内容

数组的join(string val)可以将数组元素连接起来,并且用中间插入val,
当在网页上交互显示下拉框内容的时候可以将内容加载到数组内,再利用innerHTML将内容显示在出来
  <script>
   var a=new Array("cctv","sxtv","tytv");
   var a=new Array(3);
   var a=new Array();
   a[0]="cctv";
   a[1]="sxtv";
   a[2]="tytv";
   a[3]="xzy";
   document.writeln(a.join('<br>'));//如果直接用a.join(),则默认会用,分割
  </script>
显示:
cctv
sxtv
tytv
xzy
用这种方式连接字符串要比 s=s+”ddd”快的多
sort:数组排序 (从小到大)

var arr=new Array(1000)
arr[0]="xbc1";
arr[1]="bcx2";
arr[2]="cctv3";
arr[5]="xctv4";
arr.sort();
for(i=0;i<arr.length;i++)
{
 if(arr[i]!=null)
 document.writeln(arr[i]);
}
 reverse:数组反向,和sort配合使用能实现从大到小排序
 var arr=new Array()
 arr[0]="a1";
 arr[1]="a2";
 arr[2]="a3";
 arr[3]="a4";
 arr.push("邢志云");
 arr.push("0123");
 //arr.sort();
 arr.reverse();//数组反向排列
 for(i=0;i<arr.length;i++)
 {
  document.writeln(arr[i]);
 }
 //显示: 0123 邢志云 a4 a3 a2 a1

slice:数组截断后赋值给另外一个数组(不改变原始数组)
var xzy1=new Array();
xzy1=["a","b","c","hello","usa","eng"];
//     0   1   2     3      4     5
var xzy2=xzy1.slice(2,4);//从数组xzy1的2号元素开始到4号元素停止的值结束转成一个数组
for(var i=0;i<xzy2.length;i++)
{
 document.write(xzy2[i]+":");//显示c hello
}
也可以这么写
<script>
var xzy1=new Array();
xzy1=["a","b","c","hello","usa","eng"];
//     0   1   2     3      4     5
var xzy2=Array.prototype.slice.call(xzy1,2,4);//从数组xzy1的2号元素开始到4号元素停止的值结束转成一个数组
for(var i=0;i<xzy2.length;i++)
{
 alert(xzy2[i]);//显示c hello
}
</script>

 splice:数组截断或清空(改变原始数组)
 var arr=new Array();
 var s;
 arr[0]="a1";
 arr[1]="a2";
 arr[2]="a3";
 arr[3]="a4";
 arr[4]="a5";
 arr[5]="a6";
 var arr2=arr.splice(3,2,"x1","x2");//从3号开始的2个元素,用x1和x2替换,并把替换下的值重新赋给数组arr2
            //如果没有参数"x1","x2",则对应的2个元素会从arr中删除,后面的前推
 for(i=0;i<arr.length;i++)
 {
  document.write(arr[i]+":");//显示: a1:a2:a3:x1:x2:a6:
 }
    
 
 document.write("<br/>");
 for(i=0;i<arr2.length;i++)
 {
  document.write(arr2[i]+":");//显示:  a4:a5:
 }
 利用splice来清空数组
 var arr=new Array();
 arr[0]="a1";
 arr[1]="a2";
 arr[2]="a3";
 arr[3]="a4";
 arr[4]="a5";
 arr[5]="a6";
 alert(arr.length);//显示6
 arr.splice(0,100000000);//可以理解为把arr数组清空,又回到初始状态
 alert(arr.length);//显示0

 concat:数组连接
 var arr=new Array();
 var s;
 arr[0]="a1";
 arr[1]="a2";
 arr[2]="a3";
 arr[3]="a4";
 arr[4]="a5";
 arr[5]="a6";
 var arr2=["b1","b2","b3"];
 var arr3=arr.concat(arr2);
 for(i=0;i<arr3.length;i++)
 {
  document.write(arr3[i]+":");//显示: a1:a2:a3:a4:a5:a6:b1:b2:b3:
 }
 使用Map
map1:
<script>

var map = {};

map["张三"] = "1362348754";
map["李四"] = "0351-98476345";
map["王五"] = "0358-4873622";

alert(map["李四"]);
</script>

用map={}就可以把map清空;
map2:
<script>

var map = new Array();

map["张三"] = "1362348754";
map["李四"] = "0351-98476345";
map["王五"] = "0358-4873622";

alert(map["李四"]);//显示:0351-98476345
alert(map.length);//这里map.length显示为0


map[0] = "0358-4873622";
map[1] = "0358-4873622";
map[2] = "0358-4873622";
alert(map.length);//这里map.length显示为3
for(var i=0;i<map.length;i++)
{
 document.write(map[i]);
}
alert(map["李四"]);//显示:0351-98476345
</script>
map3:
var map={"姓名":"邢志云","性别":"男","年龄":34}
map.婚否="已婚";//可以动态添加
eval("map.国籍='中华'");//但map.后面的标识符只能是以字符开头的,并且不能有-所以全球标识符不宜用在这里
alert(map.国籍);
//alert(map.姓名);//邢志云
//alert(map.年龄);//34
map["民族"]="汉族";//也可以像第一条中那样赋值,但这种可以用任意串做键,如: map["1-2"]="汉族";alert(map.姓名+":"+map["1-2"]);//也能正常显示
alert(map.姓名+":"+map.民族);
for(var colname in map)
{
 alert(colname );//姓名 性别 年龄 婚否
}
for(var colname in map)
{
 alert(map[colname]);//邢志云 男 34 已婚
}
还可以这样
var s="'姓名':'邢志云','性别':'男',35:'年龄'";
eval("var map={"+s+"}");
alert(map["姓名"]);
或者
var s="姓名:'邢志云',性别:'男',35:'年龄'";
eval("var map={"+s+"}");
alert(map["姓名"]);
还可以嵌套
var map=
{
"人员":
 {
 "张三":"男"
 ,"赵六":"女"
 }
,"车辆":
 {
 "桑塔纳":"6万"
 ,"别克":"10万"
 }
,"年龄":34
}
alert(map.人员.赵六);//女
alert(map.车辆.桑塔纳);//6万
使用自定义的属性的数组
var a=new Array();
a[0]={};
a[0].姓名="邢志云";
a[0].年龄=32;

a[1]={};
a[1].姓名="李四";
a[1].年龄=28;
for(var i=0;i<a.length;i++)
{
 alert(a[i].姓名+":"+a[i].年龄);
}

分享到:
评论

相关推荐

    js数组说明大全

    对javascript中数组的使用比较完善的说明

    使用JavaScript数组模拟Java的Hashtable集合

    于是,本人使用JavaScript的数组模拟Hashtable集合,说明JavaScript数组的特别之外。 环境:Windows XP Professional, IE 6.0 阅读对象:所有学习JavaScript的学员。 注:本示例代码注释非常详细,请仔细阅读体会...

    Javascript数组操作高级心得整理

     使用[removed]调用外部的JavaScript(.js文件) 4  如何与老浏览器打交道 4 (2) 把JavaScript代码放到HTML页面不同的位置 4  把JavaScript代码放到HTML&lt;body&gt;部分 4  把JavaScript代码放到HTML&lt;head...

    Js数组排序函数sort()介绍

    JavaScript实现多维数组、对象数组排序,其实用的就是原生的sort()方法,用于对数组的元素进行排序。 sort() 方法用于对数组的元素进行排序。语法如下: arrayObject.sort(sortby) 返回值为对数组的引用。请注意,...

    javascript数组操作方法小结和3个属性详细介绍

    最近一直在用js,好好研究了下js数组的操作,在这里总结一下。 1、数组的创建 代码如下: var arrayObj = new Array(); //创建一个数组 var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是...

    javascript的日期对象、数组对象、二维数组使用说明

    主要介绍了javascript的日期对象、数组对象、二维数组使用说明,需要的朋友可以参考下

    有趣的JavaScript数组长度问题代码说明

    有趣的JavaScript数组代码示例,学习js的朋友可以参考下。注意以下的情况。

    js判断数组包含某个值.pdf

    JS判断数组包含某个值 这份资源详细介绍了如何在JavaScript中判断数组是否包含某个值。文档中提供了多种实现方法,包括使用includes()函数、使用indexOf()函数、使用filter()函数等多种方式。每一种方法都有详细的...

    JS数组进阶示例【数组的几种函数用法】

    前面介绍了js数组的基本定义与使用方法,这里再来进一步说明一下js数组函数。 &lt;html&gt; &lt;head&gt; &lt;title&gt;js数组进阶&lt;/title&gt; &lt;meta charset="UTF-8"/&gt; [removed] var arr=[2,...

    javascript数组操作总结和属性、方法介绍

    //创建一个数组并赋值要说明的是,虽然第二种方法创建数组指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为5,仍然可以将元素存储在规定长度以外的,注意:这时长度会随之改变。2、数组的...

    js删除数组中指定元素,多种方法

    内容概要:介绍js删除数组中指定元素的多种方法,分为四个大类:删除第一个元素;删除最后一个元素;删除数组中某个指定下标的元素;删除数组中某个指定元素。每个大类至少提供了三种删除方法,各有优劣,但都能实现...

    JS数组array元素的添加和删除方法代码实例

    js数组元素的添加和删除一直比较迷惑,今天终于找到详细说明的资料了,先给个我测试的代码^-^ var arr = new Array(); arr[0] = aaa; arr[1] = bbb; arr[2] = ccc; //alert&#40;arr.length&#41;;//3 arr.pop(); //...

    JS数组转字符串实现方法解析

    JavaScript 允许数组与字符串之间相互转换。其中 Array 方法对象定义了 3 个方法,可以把数组转换为字符串,如表所示。 数组方法 说明 toString() 将数组转换成一个字符串 toLocalString() 把数组转换成本...

    js中数组(Array)的排序(sort)注意事项说明.docx

    js中数组(Array)的排序(sort)注意事项说明.docx

    JavaScript数组Array对象增加和删除元素方法总结

    本文实例总结了JavaScript数组Array对象增加和删除元素方法。分享给大家供大家参考。具体分析如下: pop 方法 移除数组中的最后一个元素并返回该元素。 arrayObj.pop( ) 必选的 arrayObj 引用是一个 Array 对象。 ...

    javascript数组元素删除方法delete和splice解析

    说明:delete: 只是被删除的元素变成了 undefined ,即数组长度不变 //定义数组 var array=["aa","dd","cc","aa"]; //方法1:delete删除数组元素 delete array[1]; //输出结果 : ["aa",undefined,"cc","aa"] 输出...

    js删除数组中指定元素-多种方法

    这份资源详细介绍了如何在JavaScript中删除数组中的指定元素。文档中提供了多种实现方法,包括使用splice()函数、使用filter()函数、使用slice()函数和循环遍历等多种方式。每一种方法都有详细的代码示例和实现说明...

    Js的Array数组对象详解

    JavaScript数组是无类型:数组元素可以是任意类型,并且同一个数组中的不同元素也可能有不同的类型。 –《JavaScript权威指南(第六版)》 1.2 定义方式 var names = new Array(张三, 李四, 王五); //或者 var names ...

    详解JavaScript数组的操作大全

    本文给大家介绍js数组的操作非常详细,感兴趣的朋友一起学习本篇文章吧。 1、数组的创建 var arrayObj = new Array(); //创建一个数组 var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是上限...

    JavaScript数组操作详解

    要说明的是,虽然第二种方法创建数组指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为5,仍然可以将元素存储在规定长度以外的,注意:这时长度会随之改变。 2、数组的元素的访问 var ...

Global site tag (gtag.js) - Google Analytics