数组方法 Array.prototype

Posted 半夏微澜ぺ

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数组方法 Array.prototype相关的知识,希望对你有一定的参考价值。

Object.prototype

数组的值是有序的集合,每一个值叫做元素,每一个元素在数组中都有数字位置编号,也就是索引,js中数组是弱类型的,数组中可以含有不同类型的元素。数组元素甚至可以是对象或者其他数组 

长度范围:1====2的23方-1

new Array(100)//undifind*100

arr[5]=10;

arr.length//6

push()

unshift()

shift()

pop()

 

var Arr=[1,true,undifind,{x:1},[1,2,3]];

Array.prototype

Array.prototype.join()   默认, 可以自定义-------将数组转换成字符串

demo:

创建一定长度的固定字符循环字符串

new Array(2).join("ab");//abab

new Array(100),创建长度为100的数组,每一个元素是undifind,join中会忽略undifind

Array.prototype.reverse=======将数组逆序,会改变原来的数组

Array.prototype.sort()========对数组进行排序(默认是按字符串进行排序,可以自定义排序的方法)   原数组被修改

Array.prototype.concat()   数组合并   原数组没有被修改

Array.prototype.slice()=====返回部分数组   左闭右开区间   支持负数   -1表示最后一个元素    -2表示倒数第二个元素    原数组不会改变

Array.prototype.splice()======数组拼接    修改原数组     可以接受两个参数   第二个参数表示删除元素的长度   返回被删除的元素

Array.prototype.forEach()   数组遍历   参数是函数  三个参数   1 是对应的元素 2 是下标   3 是遍历的数组本身   不会修改原来的数组

Array.prototype.map()数组映射   不会修改原来的数组

Array.prototype.filter()  数组过滤  返回符合要求的数组  不会修改原来的数组

Array.prototype.every() 返回 true  false  数组判断   所有的元素都符合

Array.prototype.some()  返回true   false  数组判断   部分元素符合就可以

Array.prototype.reduce()   将一个数组聚合为一个结果   与reduceRight的区别是默认是从数组从左到右   reduceRight是数组从右到左

Array.prototype.reduceRight()

demo:

获取数组的最大值

var arr=[30,40,3,20,10,9,8];

var max=arr.reduce(function(x,y){

return x>y?x:y;

});

可以指定初始化值

var max=arr.reduce(function(x,y){

return x>y?x:y;

},20);

返回数组arr与20只最大的数值

Array.prototype.indexOf()数组检索  可以指定开始检索的位置,第一个参数:需要检测的元素。第二个参数:开始检索的位置

Array.isArray()  isArray是Array构造器上的函数,不是原型prototype上的方法,不能直接使用一个数组进行调用

Array.isArray([]);

 

以上是关于数组方法 Array.prototype的主要内容,如果未能解决你的问题,请参考以下文章

数组常用方法——汇总

笔记js Array.prototype.slice.call(arguments) 将函数的参数转换为数组方法的见解

JavaScrip ES6数组方法

数组所有原型,数组方法

将函数的实际参数转换成数组的方法,习惯用Array.prototype.slice.call(arguments)

数组的方法之(Array.prototype.reduce() 方法)