欢迎,感谢你能来...

找到回家的路:
首页 > 前端分享 > JS/JQuery > JavaScript Array 对象
JS/JQuery

JavaScript Array 对象

作者:Fanda 发布日期:2019-05-09 围观人数:2061人

简介

Javascript的数组实质是对象,它把数组的下标转换成字符串,用其作为属性,因此它明显比真正的数组慢,但它可以更方便地使用。

Array 对象属性

属性 描述
constructor 返回对创建此对象的数组函数的引用。
length 设置或返回数组中元素的数目。
prototype 使您有能力向对象添加属性和方法。

Aarray 对象

方法 描述
concat() 连接两个或更多的数组,并返回结果。
join() 把数组的所有元素放入一个字符串。元素通过指定的分隔符进行分隔。
pop() 删除并返回数组的最后一个元素
push() 向数组的末尾添加一个或更多元素,并返回新的长度。
reverse() 颠倒数组中元素的顺序。
shift() 删除并返回数组的第一个元素
slice() 从某个已有的数组返回选定的元素
sort() 对数组的元素进行排序
splice() 删除元素,并向数组添加新元素。
unshift() 向数组的开头添加一个或更多元素,并返回新的长度。
toLocaleString() 把数组转换为本地数组,并返回结果。
toSource() 返回该对象的源代码。
valueOf() 返回数组对象的原始值
toString() 把数组转换为字符串,并返回结果。

concat() 方法



定义和用法


concat()方法用于连接两个或多个数组.


该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。



语法


arrayObject.concat(arrayX,arrayX,……,arrayX)

  • arrayX 必需。该参数可以是具体的值,也可以是数组对象。可以是任意多个。



返回值


返回一个新的数组。该数组是通过把所有

arrayX

参数添加到 arrayObject 中生成的。如果要进行 concat() 操作的参数是数组,那么添加的是数组中的元素,而不是数组。



实例

  • 在本例中,我们将把 concat() 中的参数连接到数组 a 中:
var a = [1,2,3];
document.write(a.concat(4,5));
//1,2,3,4,
  • 在本例中,我们创建了两个数组,然后使用 concat() 把它们连接起来:
var arr = ["George","John","Thomas"];
var arr2 = ["James","Adrew","Martin"];
document.write(arr.concat(arr2));
// George,John,Thomas,James,Adrew,Martin     

join() 方法



定义和用法


join() 方法用于把数组中的所有元素放入一个字符串。


元素是通过指定的分隔符进行分隔的。



语法


arrayObject.join(separator)

  • separator 可选。指定要使用的分隔符。*如果省略该参数,则使用逗号作为分隔符。*



返回值


返回一个字符串。该字符串是通过把 arrayObject 的每个元素转换为字符串,然后把这些字符串连接起来,在两个元素之间插入 separator 字符串而生成的。



实例

  • 在本例中,我们将创建一个数组,然后把它的所有元素放入一个字符串:
var arr = ["George","John","Thomas"];
document.write(arr.join())
// George,John,Thomas  
  • 在本例中,我们将使用分隔符来分隔数组中的元素:
var arr = ["George","John","Thomas"];
document.write(arr.join("."))
// George.John.Thomas        

pop() 方法



定义和用法


pop() 方法用于删除并返回数组的最后一个元素。



语法


arrayObject.pop()



返回值


arrayObject 的最后一个元素。



说明


pop() 方法将删除 arrayObject 的

最后一个元素

,把数组长度减 1,并且返回它删除的元素的值。如果数组已经为空,则 pop() 不改变数组,并返回 undefined 值。



实例

  • 在本例中,我们将创建一个数组,然后删除数组的最后一个元素。请注意,这也会改变数组的长度:
var arr = ["George","John","Thomas"];
document.write(arr)
document.write("<br />")
document.write(arr.pop())
document.write("<br />")
document.write(arr);
//George,John,Thomas
//Thomas
//George,John

push() 方法



定义和用法


push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度。



语法


arrayObject.push(newelement1,newelement2,….,newelementX)

  • newelement1 必需。要添加到数组的第一个元素。
  • newelement2 可选。要添加到数组的第二个元素。
  • newelementX 可选。可添加多个元素。



返回值


把指定的值添加到数组后的新长度。



说明


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



实例

  • 在本例中,我们将创建一个数组,并通过添加一个元素来改变其长度:
var arr = ["George","John","Thomas"];
document.write(arr + "<br />")
document.write(arr.push("James") + "<br />")
document.write(arr);
//George,John,Thomas
//4
//George,John,Thomas,James

reverse() 方法



定义和用法


reverse() 方法用于颠倒数组中元素的顺序。



语法


arrayObject.reverse()



实例

var arr = ["George","John","Thomas"];
document.write(arr + "<br />")
document.write(arr.reverse());
//George,John,Thomas
//Thomas,John,George 

shift() 方法



定义和用法


shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。



语法


arrayObject.shift()



返回值


数组原来的第一个元素的值。



说明


如果数组是空的,那么 shift() 方法将不进行任何操作,返回 undefined 值。请注意,该方法不创建新数组,而是直接修改原有的 arrayObject。



实例

var arr = ["George","John","Thomas"];
document.write(arr + "<br />")
document.write(arr.shift() + "<br />")
document.write(arr)
//George,John,Thomas
//George
//John,Thomas

slice() 方法



定义和用法


slice() 方法可从已有的数组中返回选定的元素。



语法


arrayObject.slice(start,end)

  • start 必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。
  • end 可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。



返回值


返回一个新的数组,包含从 start 到 end (不包括该元素)的 arrayObject 中的元素。



说明


请注意,该方法并不会修改数组,而是返回一个子数组。如果想删除数组中的一段元素,应该使用方法 Array.splice()。

var arr = ["George","John","Thomas"];
document.write(arr + "<br />")
document.write(arr.slice(1) + "<br />")
document.write(arr)
//George,John,Thomas
//John,Thomas
//George,John,Thomas      

sort() 方法



定义和用法


sort() 方法用于对数组的元素进行排序。



语法


arrayObject.sort(sortby)

  • sortby 可选。规定排序顺序。必须是函数。



返回值


对数组的引用。请注意,数组在原数组上进行排序,不生成副本。



说明


如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。


如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下:

  • 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。
  • 若 a 等于 b,则返回 0。
  • 若 a 大于 b,则返回一个大于 0 的值。



实例

var arr = [10,5,40,25,1000,1]
document.write(arr + "<br />")
document.write(arr.sort());
//10,5,40,25,1000,1
//1,10,1000,25,40,5



请注意,上面的代码没有按照数值的大小对数字进行排序,要实现这一点,就必须使用一个排序函数:

function sortNumber(a,b){
    return a - b;
}
var arr = [10,5,40,25,1000,1]
document.write(arr + "<br />");
document.write(arr.sort(sortNumber));
//10,5,40,25,1000,1
//1,5,10,25,40,1000

splice() 方法



定义和用法


splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。



注释:

该方法会改变原始数组。



语法


arrayObject.splice(index,howmany,item1,…..,itemX)

  • index 必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。
  • howmany 必需。要删除的项目数量。如果设置为 0,则不会删除项目。
  • item1, …, itemX 可选。向数组添加的新项目。



返回值


包含被删除项目的新数组,如果有的话。



说明


splice() 方法可删除从 index 处开始的零个或多个元素,并且用参数列表中声明的一个或多个值来替换那些被删除的元素。


如果从 arrayObject 中删除了元素,则返回的是含有被删除的元素的数组。



实例

  • 在本例中,我们将创建一个新数组,并向其添加一个元素:
var arr = new Array(6)
arr[0] = "George"
arr[1] = "John"
arr[2] = "Thomas"
arr[3] = "James"
arr[4] = "Adrew"
arr[5] = "Martin"

document.write(arr + "<br />")
arr.splice(2,0,"William")
document.write(arr + "<br />")
//George,John,Thomas,James,Adrew,Martin
//George,John,William,Thomas,James,Adrew,Martin
  • 在本例中我们将删除位于 index 2 的元素,并添加一个新元素来替代被删除的元素:
var arr = new Array(6)
arr[0] = "George"
arr[1] = "John"
arr[2] = "Thomas"
arr[3] = "James"
arr[4] = "Adrew"
arr[5] = "Martin"

document.write(arr + "<br />")
arr.splice(2,1,"William")
document.write(arr);
//George,John,Thomas,James,Adrew,Martin
//George,John,William,James,Adrew,Martin
  • 在本例中我们将删除从 index 2 (“Thomas”) 开始的三个元素,并添加一个新元素 (“William”) 来替代被删除的元素:
var arr = new Array(6)
arr[0] = "George"
arr[1] = "John"
arr[2] = "Thomas"
arr[3] = "James"
arr[4] = "Adrew"
arr[5] = "Martin"

document.write(arr + "<br />")
arr.splice(2,3,"William")
document.write(arr);
//George,John,Thomas,James,Adrew,Martin
//George,John,William,Martin

unshift() 方法



定义和用法


unshift() 方法可向数组的开头添加一个或更多元素,并返回新的长度。



语法


arrayObject.unshift(newelement1,newelement2,….,newelementX)

  • newelement1 必需。向数组添加的第一个元素。
  • newelement2 可选。向数组添加的第二个元素。
  • newelementX 可选。可添加若干个元素。



返回值


arrayObject 的新长度。



说明


unshift() 方法将把它的参数插入 arrayObject 的头部,并将已经存在的元素顺次地移到较高的下标处,以便留出空间。该方法的第一个参数将成为数组的新元素 0,如果还有第二个参数,它将成为新的元素 1,以此类推。


请注意,unshift() 方法不创建新的创建,而是直接修改原有的数组。



实例

  • 在本例中,我们将创建一个数组,并把一个元素添加到数组的开头,并返回数组的新长度:
var arr = new Array()
arr[0] = "George"
arr[1] = "John"
arr[2] = "Thomas"
document.write(arr + "<br />")
document.write(arr.unshift("William") + "<br />")
document.write(arr);
//George,John,Thomas
//4·
//William,George,John,Thomas


(完)最后献上美女一枚

 

Tags:

转载 云中不知处博客欢迎分享,转载请说明文章出处“ 来源云中不知处博客 http://www.saymiss.com/archives/62 “。
很赞哦!( 0)

( 0 )个小伙伴在吐槽

访客评论


站点统计

  • 更新时间:2023-04-17 05:40
  • 文章总数:34
  • 评论总数:34
  • 标签总数:25
  • 运行时间: 2053
我的微信
  • 网站赞助:阿里云、腾讯云、百度云、奇虎360、网易云音乐、音悦台、京东商城,哦以上这些都没有。
  • 网站制作:页面设计:Fanda;前端开发:Fanda;后台功能:Fanda;主题开发:Fanda;技术支持:Fanda。我就是天才...
免责声明
  • 1、本站个人博客模板,均为Fanda本人设计,可供个人学习和使用,未经许可不得用于任何商业目的。
  • 2、本站部分文章来自网络,请您放心,所有转载文章内容皆保留来源链接,如本站有著作权属于你的文章内容,而本站并未放上链接或有其他原因侵权,请E-mail: fzh2812@163.com,我会在48小时内删除相关内容,敬请谅解!
碎言碎语
  • 好好珍惜对你好的人,弄丢了上百度也找不回来

    2021-10-25
  • 同在一座城市,为何好久不见!

    2020-11-22
  • 三生有幸遇见你,纵使悲凉也是情

    2020-05-07
  • 忍一时风平浪静,退一步越想越气

    2020-03-21
  • 最近996

    2019-11-09
  • 最近有点忙,996啊

    2019-07-29
  • 端午3天我就没下过楼,出过门

    2019-06-09

©2019 云中不知处 Powered by WordPress 文章归档 免责声明 网站地图 百度统计