Array与Hash案例1:要求利用变量保存数据,()将变量输出。效果如下图:(图中的空格为全角空格)图1案例1效果图 案例分析:要显示的是一组人物信息,包含4个元素,每一个元素又包含名字和绰号。那么我们只需要把这8个数据分别保存到8个变量中,然后将变量打印即可。代码演示:案例1(利用变量完成)<html><head><metahttp-equiv="Content-Type"content="text/html;charset=gb2312"/><title>案例1(利用变量完成)</title></head><scripttype="text/javascript"> varname1,name2,name3,name4; varbyname1,byname2,byname3,byname4; name1="林冲",name2="吴用",name3="李逵",name4="史进"; byname1="豹子头",byname2="智多星",byname3="黑旋风",byname4="九纹龙"; ("姓名绰号<br>") ("----------------<br>") (name1+" "+byname1+"<br>") (name2+" "+byname2+"<br>") (name3+" "+byname3+"<br>") (name4+" "+byname4+"<br>")</script><body></body></html> 保存上面代码,运行效果如图1所示。 上述代码,变量过多,操作繁杂,而且不易于维护,有经验的程序员肯定不会这么写,有没有更好的办法呢?在Java中,我们学过数组的概念,将多个变量合并成一个数组实现代码优化,JavaScript中如何应用数组呢? 数组数组就是某类数据的集合,数据类型可以是整型、字符串。语法结构:数组定义及初始化/***方式1:定义数组变量后,直接初始化*/var数组名①=[元素1②,元素2,元素3……]③;/***方式2:利用Array对象定义数组*/var数组名=newArray(数组长度);var数组名=newArray(元素1,元素2,元素3……);语法解析:数组名的定义规则与变量相同。数组内元素的数据类型可以不一样。初始化数组与Java不一样,需要用中括号。代码演示:案例1(利用数组完成)<html><head><metahttp-equiv="Content-Type"content="text/html;charset=gb2312"/><title>案例1(利用数组完成)</title></head><scripttype="text/javascript"> varname=["林冲","吴用","李逵","史进"]; varbyname=newArray("豹子头","智多星","黑旋风","九纹龙"); ("姓名绰号<br>") ("----------------<br>") for(vari=0;i<;i++){ (name[i]+" "+byname[i]+"<br>") }</script><body></body></html> 代码解析:length属性可以获得数组的长度保存上面代码,运行效果如图1所示。上面的代码中,我们定义了两个数组分别保存姓名和绰号,这就要求我们在操作数组的时候两个数组的下标一定要对应,否则会出现“智多星林冲”、“九纹龙李逵”这样张冠李戴的现象。解决这样的问题,在Java中可以使用HashMap这样的键值表来实现,一个键对应一个值,不会出现交叉串位。JavaScript中的Hash表与Java中的HashMap非常相似,下面就来介绍下如何在JavaScript中应用hash表。Hash表语法结构:Hash表的定义与使用/***hash表的定义及初始化*/varhash表名={元素键:元素值①,②元素键:元素值,……};/***向hash表中添加新值*/hash表名[键]=值;/***从hash表中取值*/值=hash表名[键];语法解析:hash表中每一个元素都由一对键和值组成,键值之间用“:”分隔,实现键值对应元素和元素之间采用“,”隔开forin语句遍历hash表,通常使用forin语句语法结构:forin语句的使用for(var变量名①inHash表名②){……}语法解析:定义变量用于遍历Hash表中的每一个元素。将
JS数组、Date、String、Math 来自淘豆网m.daumloan.com转载请标明出处.