一、什么是数组?

数组是一个值的集合,每一个值都有一个索引号,从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. Wordpress prettyPhoto插件跨站脚本漏洞

    漏洞名称: Wordpress prettyPhoto插件跨站脚本漏洞 CNNVD编号: CNNVD-201311-413 发布时间: 2013-11-28 更新时间: 2013-11-28 危害等级 ...

  2. NSArray和NSMutableArray的copy和MutableCopy

    NSArray: //main.m #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { ...

  3. 在C#中设置打印机纸张大小

    using System.Drawing.Printing.PrintDocument using System.Drawing.Printing.PrinterSettings.PaperSizeC ...

  4. POJ2492 A Bug's Life 带权并查集

    分析:所谓带权并查集,就是比朴素的并查集多了一个数组,记录一些东西,例如到根的距离,或者和根的关系等 这个题,权数组为relation 代表的关系  1 和父节点不同性别,0,和父节点同性别 并查集一 ...

  5. [转]WinForm如何调用Web Service

    1.建立项目WebService和WinForm项目,这里起名为WinFormInvokeWebService,如图所示, 2.Service1.asmx代码为:(这部分其实和上篇的代码是一样的) u ...

  6. bitset位图讲解

    bitset可以用来处理位图问题,用位可以大大减少占用的空间内存,但是位图问题适合处理不重复的,在一定范围内的整数问题.用两个位图可以处理只出现一次问题 #include <bitset> ...

  7. 【前端】CSS3实现弹出效果

    36氪这个网站上的登录框弹出的时候挺帅气的,想知道它是怎么做的 .. 今天通过问新爷再加上自己琢磨琢磨写出一个小小Demo - 上代码 <!DOCTYPE html> <html&g ...

  8. linux内核系列(二)内核数据结构之链表

    双向链表 传统链表与linu内核链表的区别图: 图一 图二 从上图中看出在传统链表中各种不同链表间没有通用性,因为各个数据域不同,而在linux内核中巧妙将链表结构内嵌到数据域结构中使得不同结构之间能 ...

  9. Weka 入门2

    现在我们介绍使用Weka来对数据进行分类.对数据进行分类,我们必须先指定那一列作为预测类别.因为数据文件格式的问题,类别一般都是最后一列属性.我们可以使用setClassIndex来设置类别.然后我们 ...

  10. HDOJ-ACM1061(JAVA) Rightmost Digit

    题意:求n的n次方的个位数(1<=N<=1,000,000,000) 第一个最愚蠢的办法就是暴力破解,没什么意义,当然,还是实现来玩玩. 以下是JAVA暴力破解: import java. ...