欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JavaAcript 数组对象常用属性

程序员文章站 2022-05-04 13:32:01
concat() 用于连接两个或多个数组。该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。 every() 用于检测数组所有元素是否都符合指定条件(通过函数提供)。 every() 方法使用指定函数检测数组中的所有元素: 如果数组中检测到有一个元素不满足,则整个表达式返回 false , ......

concat() 

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

var a = ["aa","ccc"];
var b = ["vv","mm"];
var c = ["123"];
var d = a.contac(b,c);  ==> ["aa","ccc","vv","mm","123"]

every()

用于检测数组所有元素是否都符合指定条件(通过函数提供)。

  every() 方法使用指定函数检测数组中的所有元素:

  • 如果数组中检测到有一个元素不满足,则整个表达式返回 false ,且剩余的元素不会再进行检测。
  • 如果所有元素都满足条件,则返回 true。

      注意: every() 不会对空数组进行检测。

      注意: every() 不会改变原始数组。

var ary = [3,4,5,6,7]
var result = ary.every(function(item){
    return item>5;          
}) ==> false

filter()

创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。

  注意: filter() 不会对空数组进行检测。

  注意: filter() 不会改变原始数组。

var ary = [2,3,5,6,7];
var result = ary.filter(function(item){
    return item>3;
}); ==> [5,6,7]

foreach()

用于调用数组的每个元素,并将元素传递给回调函数。

var ary = [3,4,5,6,7]
var result = ary.foreach(function(item,index){
   console.log(item,index)         
});

 includes()

用来判断一个数组是否包含一个指定的值,如果是返回 true,否则false。

arr.includes(searchelement)
arr.includes(searchelement, fromindex)
// searchelement   要查找的元素
// fromindex  开始查找的位置,默认为0;如果fromindex 大于等于数组长度 ,则返回 false ,该数组不会被搜索
//如果 fromindex 为负值,计算出的索引将作为开始搜索searchelement的位置。如果计算出的索引小于 0,则整个数组都会被搜索。
var arr = ['a', 'b', 'c'];
arr.includes('a'); // true
arr.includes('a', -100); // true

indexof()

可返回数组中某个指定的元素位置。如果在数组中没找到指定元素则返回 -1。

var num = [1,2,3,4,'apple'];
var a = num.indexof("apple");  //4

lastindexof()

可返回一个指定的元素在数组中最后出现的位置,在一个数组中的指定位置从后向前搜索。如果要检索的元素没有出现,则该方法返回 -1。

var num = [1,2,3,4,'apple'];
var a = num.lastindexof("apple");  //4

isarray()

用于判断一个对象是否为数组。如果对象是数组返回 true,否则返回 false。

var item = [];
array.isarray(item);  //true

join()

用于把数组中的所有元素转换一个字符串。元素是通过指定的分隔符进行分隔的。

var fruits = ["banana", "orange", "apple", "mango"];
var energy = fruits.join();  //banana,orange,apple,mango
var energy = fruits.join("|");  //banana|orange|apple|mango

map()

返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。

  map() 方法按照原始数组元素顺序依次处理元素。

  注意: map() 不会对空数组进行检测。

  注意: map() 不会改变原始数组。

var ary= [4,9,16,25];
var result = ary.map(math.sqrt); //result ==> 2,3,4,5

pop()

用于删除数组的最后一个元素并返回删除的元素。

var ary = [2,4,5,6];
var del = ary.pop(); //del ==> 6
// ary ==> 2,4,5

push()

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

var ary = ['aa','bb','cc'];
var result = ary.push('ss');  //result ==> 4
//ary ==> ['aa','bb','cc','ss']

shift()

用于删除并返回数组的第一个元素。

var ary = [2,4,5,6];
var del = ary.shift(); //del ==> 2 
// ary ==> 4,5,6

unshift()

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

var ary = ['aa','bb','cc'];
var result = ary.unshift('ss');  //result ==> 4
//ary ==> ['ss','aa','bb','cc']

reduce()

接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。

  这个函数必须接收两个参数,reduce()把结果继续和序列的下一个元素做累积计算。

  注意: reduce() 对于空数组是不会执行回调函数的。

var arr = [1, 3, 5, 7, 9];
arr.reduce(function (x, y) {
    return x + y;
}); // 25

reduceright() 方法的功能和 reduce() 功能是一样的,不同的是 reduceright() 从数组的末尾向前将数组中的数组项做累加。

reverse()

用于颠倒数组中元素的顺序。

var fruits = [1, 2, 3, 4];
fruits.reverse();  // [4,3,2,1]

slice()

可从已有的数组中返回选定的元素。

  slice()方法可提取字符串的某个部分,并以新的字符串返回被提取的部分。

  注意: slice() 方法不会改变原始数组。

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

array.slice(start, end)
//start 可选。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。
//end 可选。规定从何处结束选取。
//该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。
//如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。
var fruits = ["banana", "orange", "lemon", "apple", "mango"];
var citrus = fruits.slice(1,3);   // ["orange", "lemon"]

some()

用于检测数组中的元素是否满足指定条件(函数提供)。

some() 方法会依次执行数组的每个元素:

  • 如果有一个元素满足条件,则表达式返回true , 剩余的元素不会再执行检测。
  • 如果没有满足条件的元素,则返回false。
var arr = [1, 3, 5, 7, 9];
arr.some(function (item) {
    return item>4;
}); // true

sort()

用于对数组的元素进行排序。返回新的数组

  排序顺序可以是字母或数字,并按升序或降序。默认排序顺序为按字母升序。

  注意:当数字是按字母顺序排列时"40"将排在"5"前面。

  使用数字排序,你必须通过一个函数作为参数来调用。

  函数指定数字是按照升序还是降序排列。

  注意: 这种方法会改变原始数组!。

var fruits = ["banana", "orange", "apple", "mango"];
fruits.sort();   // apple,banana,mango,orange

//升序
var points = [40,100,1,5,25,10];
points.sort(function(a,b){return a-b});  //1,5,10,25,40,100

//降序
var points = [40,100,1,5,25,10];
points.sort(function(a,b){return b-a});  // 100,40,25,10,5,1

splice()

用于插入、删除或替换数组的元素。

  注意:这种方法会改变原始数组!

array.splice(index,howmany,item1,.....,itemx)
//index 必需。规定从何处添加/删除元素。该参数是开始插入和(或)删除的数组元素的下标,必须是数字。
//howmany      必需。规定应该删除多少元素。必须是数字,但可以是 "0"。如果未规定此参数,则删除从 index 开始到原数组结尾的所有元素。
//item1, ..., itemx  可选。要添加到数组的新元素

//如果从 arrayobject 中删除了元素,则返回的是含有被删除的元素的数组。
//移除数组的第三个元素,并在数组第三个位置添加新元素:
var fruits = ["banana", "orange", "apple", "mango"];
fruits.splice(2,1,"lemon","kiwi"); //["banana", "orange", "lemon","kiwi","mango"]

//从第三个位置开始删除数组后的两个元素:
var fruits = ["banana", "orange", "apple", "mango"];
fruits.splice(2,2);  //["banana", "orange"]

tostring()

可把数组转换为字符串,并返回结果。

注意: 数组中的元素之间用逗号分隔。

array.tostring()

valueof()

返回 array 对象的原始值。

  该原始值由 array 对象派生的所有对象继承。

  valueof() 方法通常由 javascript 在后台自动调用,并不显式地出现在代码中。

  注意: valueof() 方法不会改变原数组。

//valueof() 是数组对象的默认方法。
// fruits.valueof()与 fruits返回值一样。
var fruits = ["banana", "orange", "apple", "mango"];
var v=fruits.valueof();