一、什么是数组?

数组是一个值的集合,每一个值都有一个索引号,从0开始,每个索引都有一个相应的值,根据需要添加更多数值。

好比一个团,团里有很多人。如下使用数组存储5个学生成绩:

二、如何创建数组

使用数组之前先要创建,而且需要把数组本身赋至一个变量

{

  创建数组语法:

    var myarray=new Array();

  创建数组的同时,还可以为数组指定长度,长度可以任意指定。

    var myarray = new Array(8);//创建数组,存储8个数据

}

{

  注意:

    1、创建的新数组是空数组,没有值,如输出,则显示undefined

    2、虽然创建数组时,指定了长度,但实际上数组都是变长的,也就是说即使指定了长度为8,仍然可以将元素存储在规定长度以外。

}

三、数组赋值

数组的表达方式:

第一步:创建数组var myarr = new Array();

第二步:给数组赋值

    myarr[1]="张三";

    myarr[2]="李四";

{

  Eg:创建一个数组,用于存储5个人的数学成绩

       var myarray=new Array();//创建一个新的空数组

    myarray[0]=66;//存储第1个人的成绩

    myarray[1]=80;//存储第2个人的成绩

    myarray[2]=90;//存储第3个人的成绩

      myarray[3]=77;//存储第4个人的成绩

    myarray[4]=59;//存储第5个人的成绩

}

注意:数组每个值有一个索引号,从0开始

{

  上例简单方法

  1、var myarry = new Array(66,80,90,77,59);//创建数组同时赋值

  2、var myarry = [66,80,90,77,59]//直接输入一个数组(称“字面量数组”)

}

注意:数组存储的数据可以是任何类型(数字、字符、布尔值等)

四、向数组增加一个新元素

myarray[5]=88;//使用一个新索引,为数组增加一个新元素。

五、使用数组元素

数组中每一个值有一个索引号,从0开始。

如下图,marray变量存储6个人的成绩:

要得到一个数组元素的值,只需引用数组变量并且提供一个索引

Eg:

第一个人成绩表示方法:marray[0]

第三个人成绩表示方法:marray[2]

六、数组属性length

想要知道数组的大小,可以引用数组的一个属性length。

length表示数组的长度,即数组中元素的个数。

{

语法:

  myarray.length;//获取数组myarray的长度

注:因为数组的索引是由0开始,所以一个数组的上下限分别为:0和length-1.

如:数组长度是5,上下限分别是0和4

}

{

  Eg:

    var arr=[55,32,5,90,60,98,76,54];//包含8个数值的数组arr

    document.write(arr.length);//显示数组长度8

    document.write(arr[7]);//显示第8个元素的值54

}

{

  注:JS数组的length属性是可变的,这一点需要特别注意。

      arr.length=10;//增大数组的长度

      document.write(arr.length);//数组长度已经变为10

}

{

  数组随元素的增加,长度也会改变,如:

    var arr=[98,76,54,56,76];//包含5个数值的数组

    document.write(arr.length);//显示数组的长度5

    arr[15]=34;//增加元素,使用索引为15,赋值为34

    alert(arr.length);//显示数组的长度16

}

七、二维数组

一维数组,看成是一组盒子,每个盒子只能放一个内容

一维数组表示:myarray[ ]

二维数组,看出是一个盒子,不过每个盒子里还可以放多个盒子。

注:二维数组的两个维度的索引值也是从0开始,两个维度的最后一个索引值为长度-1.

  1、二维数组的定义方法一

    var myarr = new Array();  //先声明一维

    for(var i=0;i<2;i++){  //一维长度为2

      myarr[i] = new Array();  //再声明二维

      for(var j=0;j<3;j++){  //二维长度为3

      myarr[i][j]=i+j;  //赋值,每个数组元素的值为i+j

      }

    }

表格表示

  2、二维数组的定义方法二

    var Myarr=[[0, 1, 2][1, 2, 3]]

  3、赋值

    myarr[0][1]=5;//将5的值传入到数组中,覆盖原有值

    说明:myarr[0][1], 0表示表的行,1表示表的列。

JavaScript入门(5)的更多相关文章

  1. JavaScript入门篇 编程练习

    编程挑战 一.定义"改变颜色"的函数 提示: obj.style.color obj.style.backgroundColor 二.定义"改变宽高"的函数 提 ...

  2. JavaScript入门

    本篇内容是学习慕课网相关课程后,总结出可能未来会忘记的内容 (一)JavaScript入门操作 1.js代码插入位置,以及执行顺序 <head> <script type=" ...

  3. 慕课网JavaScript入门篇课程笔记

    1.js注释很重要 单行注释,在注释内容前加符号 “//”. <script type="text/javascript"> document.write(" ...

  4. JavaScript入门基础

    JavaScript基本语法 1.运算符 运算符就是完成操作的一系列符号,它有七类: 赋值运算符(=,+=,-=,*=,/=,%=,<<=,>>=,|=,&=).算术运 ...

  5. JavaScript入门介绍(二)

    JavaScript入门介绍 [函数] 函数function 是Javascript的基础模块单元,用于代码的复用.信息影藏和组合调用. function a(){} 函数对象Function Lit ...

  6. JavaScript入门介绍(一)

    JavaScript入门介绍 [经常使用的调试工具][w3school.com.cn在线编辑] [Chrome浏览器 开发调试工具]按F121.代码后台输出调试:console.log("t ...

  7. 开心菜鸟系列----函数作用域(javascript入门篇)

      1 <!DOCTYPE html>   2 <html>   3 <script src="./jquery-1.7.2.js"></ ...

  8. 开心菜鸟系列----变量的解读(javascript入门篇)

                       console.info(         console.info(window['weiwu'])          console.info(window. ...

  9. javascript入门视频第一天 小案例制作 零基础开始学习javascript

    JavaScript 是我们网页设计师必备的技能之一.我们主要用javascript来写的是网页特效.我们从零基础开始学习javascript入门. 但是,好的同学刚开始不知道怎么学习,接触js,因此 ...

  10. ArcGIS API for JavaScript 入门教程[0] 目录

    随时翻看. 转载注明出处,博客园/CSDN/B站:秋意正寒. Part 1 必看 ArcGIS API for JavaScript 入门教程[1] 渊源 你还真不一定知道这是啥.非得学吗? ArcG ...

随机推荐

  1. BZOJ3166: [Heoi2013]Alo

    3166: [Heoi2013]Alo Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 394  Solved: 204[Submit][Status] ...

  2. -_-#【CSS 优化】

    高性能CSS 关于css通配符性能问题不完全测试 CSS的渲染效率 border: none; /* 不写 border: 0; 但几乎都是写 border: 0;的.. */ 不要使用过小的图片做背 ...

  3. 生产环境下JAVA进程高CPU占用故障排查

    问题描述:生产环境下的某台tomcat7服务器,在刚发布时的时候一切都很正常,在运行一段时间后就出现CPU占用很高的问题,基本上是负载一天比一天高. 问题分析:1,程序属于CPU密集型,和开发沟通过, ...

  4. Vlan技术总结

    VLAN主要有两个作用: vlan可以有效的控制广播域的范围 vlan可以分组设备,增强局域网的安全性(业务隔离) vlan的范围: 一共有4096个vlan,vlan 1为默认vlan.但其中vla ...

  5. D3D12 图形编程

    D3D 11到D3D 12的重大改进 Direct3D 12 的编程模型和 Direct3D 11大相径庭.在Direct3D 12中,应用程序和硬件靠得近多了,这在以前是从未有过的. 这让D3D12 ...

  6. nyoj重建二叉树(不真的建立)

      感觉c++很陌生啊 题目很简单,给你一棵二叉树的后序和中序序列,求出它的前序序列(So easy!). 输入 输入有多组数据(少于100组),以文件结尾结束.每组数据仅一行,包括两个字符串,中间用 ...

  7. CURL超时处理

    一般会设置一个超时时间1S,就是说如果php那边在1S内没有返回给urlserver的话就忽略掉该请求,及不阻塞等待返回了,直接处理下面的操作. 现在php那边有时候会卡,这样一卡就无法再1S内返回消 ...

  8. linux下编译安卓ffmpeg

    本次编译属于2013年6月项目的一部分,重新修改使用. 为统一工程版本 ffmpeg版本为1.2.1 本次的目录结构为 工程目录/jni/Android.mk 工程目录/jni/Application ...

  9. oracle flashback

    一.Flashback闪回技术概述:当Oracle数据库发生逻辑错误时,必须使用flashback技术,实现快速和方便的恢复数据.对于人为错误,要确定受到错误事务影响的对象或者记录是非常困难的.使用f ...

  10. NSNumber和Int之间的转换

    int 转 NSNumber: [NSNumber numberWithInt:(int)];   NSNumber 转 int [(NSNumber) intValue];   其他数据类型类似 有 ...