JavaScript Array

本文详细介绍了JavaScript中的Array对象,包括创建方式、属性如length、constructor、prototype,以及concat、join、pop、push等方法的使用,帮助读者全面掌握Array对象的用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JavaScript Array对象

JavaScript 中的所有事物都是对象:字符串、数字、数组、日期,等等。

1、Array对象创建

Array 对象用于在单个的变量中存储多个值。创建语法如下:

var cars=new Array(); //后续cars[i]=***添加元素
var cars=new Array(size); //size指定数组长度
var cars=new Array(element0, element1, ..., elementn);
//参数 element ..., elementn 是参数列表

或者

var cars=["Audi","BMW","Volvo"];

或者

var cars[]; //创建空数组

2、Array对象属性

  • constructor: 返回对创建此对象的数组函数的引用。
var test=new Array();
if (test.constructor==Array){ //true
    document.write("This is an Array");
}
  • length: 设置或返回数组中元素的数目。(常用)
    • 数组的 length 属性在用构造函数 Array() 创建数组时被初始化。给数组添加新元素时,如果必要,将更新 length 的值。
    • 设置 length 属性可改变数组的大小。如果设置的值比其当前值小,数组将被截断,其尾部的元素将丢失。如果设置的值比它的当前值大,数组将增大,新的元素被添加到数组的尾部,它们的值为 undefined
  • prototype: 使您有能力向对象(包括数组的所有对象)添加属性和方法。
var bill=new Array("Bill Gates","Engineer",1985);
employee.prototype.salary=null;//添加一个新属性
bill.salary=20000;//给新属性赋值
document.write(bill.salary);//2000

3、Array对象方法

  • concat() :连接两个或更多的数组,并返回结果。

    • 该方法返回一个新的数组,不会改变现有的数组。
    • arr.contat(parameter1,parameter2,…)是把参数加入数组arr尾部。
    • arr.contat(arr1,arr2,…)是把多个数组连接起来,组成一个新的数组。
  • join():把数组的所有元素放入一个字符串。元素通过指定的分隔符进行分隔。

    • 返回一个字符串。该字符串是通过把Array对象的每个元素转换为字符串,然后把这些字符串连接起来,在两个元素之间插入分隔符而生成的。
var arr = new Array( "George","John","Thomas");
var str = arr.join();
  • pop(): 删除并返回数组的最后一个元素。

    • pop() 方法将删除 Array对象的最后一个元素,把数组长度减 1,并且返回它删除的元素的值。如果数组已经为空,则 pop() 不改变数组,并返回 undefined 值。
  • push():向数组的末尾添加一个或更多元素,并返回新的长度。

    • push() 方法可把它的参数顺序添加到 arrayObject 的尾部。它直接修改数组,而不是创建一个新的数组。push() 方法和 pop() 方法使用数组提供的先进后出栈的功能。
    • 参数可以很多个。
  • reverse():颠倒数组中元素的顺序。

    • 该方法会改变原来的数组,而不会创建新的数组。
  • shift() :删除并返回数组的第一个元素。

    • 如果数组是空的,那么 shift() 方法将不进行任何操作,返回 undefined 值。
    • 该方法不创建新数组,直接修改原有的数组。
    • 数组的长度会减1。
  • slice(start, end):从某个已有的数组返回选定的元素。

    • start,必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置.
    • end,可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。
    • 返回一个新的数组,包含从 start 到 end (不包括该元素)的数组元素。
  • sort():对数组的元素进行排序。

    • 数组在原数组上进行排序,不生成新的数组。
    • sort(sortby),参数可选。它规定排序顺序,必须是函数。
    • 如果调用该方法时没有使用参数,将按照字母顺序对数组中的元素进行排序,即按照字符编码的顺序进行排序。某些情况需要先把数组的元素都转换成字符串,以便进行比较。如果想按照其他标准进行排序,就需要提供比较函数sortby,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。
function compare(a,b) //排序规则函数
{
return a - b
}
var arr = new Array(10,5,38,21,9);
arr.sort(compare);
  • splice():删除元素,并向数组添加新元素。

    • 该方法直接修改数组,如果从数组中删除了元素,则返回的是含有被删除的元素的数组。
    • splice(index,num,item1,…..,itemN),替换参数可以是多个。num为0,相当于在数组中插入新元素。
var arr = new Array("George","John","Thomas","James","Martin");
arr.splice(1,2,"Joanna"); //从arr[1]开始删除2个元素,再用"Joanna"替换被删除的元素
document.write(arr); //George,Joanna,James,Martin
  • toString() 把数组转换为字符串,并返回结果。

    • 数组中的元素之间用逗号分隔。
  • toLocaleString():把数组转换为本地数组,并返回结果。

    • 首先对每个数组元素调用 toLocaleString() 方法,再使用地区特定的分隔符把生成的字符串连接起来,形成一个字符串。
  • unshift() :向数组的开头添加一个或更多元素,并返回新的长度。

    • 参数可以很多个。
    • 将参数插入数组的头部,并将已经存在的元素顺次地移到较高的下标处,以便留出空间。第一个参数成为数组的新元素 0,第二个参数成为新的元素 1,以此类推。
    • 该方法不创建新的创建,而是直接修改原有的数组。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值