JavaScript中Array类型中的方法
Array类型
检测数组
检测数组有以下几种方法,
- instanceof
var arr=['前端','保定','就业']; console.log(arr instanceof Array);//true
- Object.prototype.toString.call()方法
var arr=['前端','保定','就业']; console.log(Object.prototype.toString.call(arr));//[object Array]
- Array.prototype.isPrototypeOf()
var arr=['前端','保定','就业']; console.log(Array.prototype.isPrototypeOf(arr));//true
- Array.isArray()
var arr=['前端','保定','就业']; console.log(Array.isArray(arr));//true
转换数组
- 利用toString()方法将数组转换为字符串
var arr=['前端','深圳','保定']; console.log(arr.toString());//输出结果字符串前端,深圳,保定
- valueOf()转换原始值
var obj={ name:'张三', } console.log(obj.valueOf());//{name:张三}
进出栈方法
- push();在数组最后面添加新的元素
var arr=['前端','保定']; arr.push('深圳'); console.log(arr);//['前端','保定','深圳']
- pop();在数组最后面删除元素
var arr=['前端','java','js']; arr.pop(); console.log(arr);//['前端','java']
- unshift();在数组最前面添加新的元素
var arr=['前端','深圳']; arr.unshift('JavaScript'); console.log(arr);//['JavaScript','前端','深圳']
- shift();在数组最前面删除元素
var arr=['前端','深圳','JavaScript']; arr.shift(); console.log(arr);//['深圳','JavaScript']
排序方法
- reverse()数组翻转
var arr=[1,2,3,4,5]; console.log(arr.reverse());//[5,4,3,2,1]
- sort()方法:对数组中的元素进行排序,并不是从小到大的排序,会影响原有数组元素的顺序
//从下列这段代码可以看出,sort()并不能实现从小到大的排序 var arr=[1,3,5,10,4,2]; console.log(arr.sort());//[ 1, 10, 2, 3, 4, 5 ] //解决以上sort()不能以小到大的顺序排列的问题 var result=arr.sort(function(a,b){ if(a>b){ return 1; } }); console.log(result);
连接方法
concat()用于数组之间的拼接
var arr=[1,2,3,4,5]; var arr1=[6,7,8,9,10]; console.log(arr.concat(6));//[1,2,3,4,5,6] console.log(arr.concat([7,8,9]));//[1,2,3,4,5,7,8,9] console.log(arr.concat(arr1));//[1,2,3,4,5,6,7,8,9,10]
操作方法
- splice(删除开始位置,删除的元素个数)方法:用于删除当前数组指定位置指定个数的元素
var arr=[1,2,3,4,5]; /*从arr的0位置开始删除两个元素,删除掉的两个元素被result变量接住了*/ var result=arr.splice(0,2); console.log(result);//[1,2] console.log(arr);//[3,4,5] //也可以用splice给数组添加元素,默认在数组最前面添加 //设置从位置0开始,删除0个,再添加新的元素 var result1=arr.splice(0,0,6,7,8); console.log(arr);//[1,2,3,4,5,6,7,8]
- slice()截取指定数组中的元素,可以传入两个参数,第一个是开始截取的位置,从0开始,第二个是结束截取的位置,截取不到最后一位,而是截取最后一位的前一个元素,截取的元素返回新的数组
var arr=[1,2,3]; var result=arr.slice(0,2); console.log(result);//[1,2]
检索方法
- indexOf()用于检查数组中是否包含指定元素内容,返回元素所在的位置,从左至右顺序进行检查,只返回第一个匹配元素的位置,后面如果还有相同的元素不考虑,如果该元素不存在数组中,返回-1
var arr=['张三','李四','小明']; console.log(arr.indexOf('张三'));//0 console.log(arr.indexOf('小红'));//-1
- lastIndexOf()用于检查数组中是否包含指定元素内容,返回元素所在的位置,从右至左顺序进行检查,只返回第一个匹配元素的位置,后面如果还有相同的元素不考虑,如果该元素不存在数组中,返回-1
var arr=['张三','李四','小明']; console.log(arr.lastIndexOf('李四'));//1
forEach()方法
用于遍历指定数组
callback:表示回调函数
currentValue:表示遍历数组得到每个元素
index:表示遍历数组得到每个元素对应的索引值
array:表示遍历的数组
var arr=['张三','李四','小红','小明']; arr.forEach(function(value,index,array){ console.log(vaule); console.log(index); console.log(array); });
迭代方法
判断数组的元素是否符合条件,符合返回true,否则返回false
var arr=[1,2,3,4,5]; var result=arr.every(function(currentVaule,index,array){ return (cunrrentValue <=5); }); console.log(result);//true
归并方法
var arr=[1,2,3,4,5]; arr.reduce(function(accumulator,currentValue,currentIndex,array){ console.log(accumulator); return accumulator+currentValue; });
相关推荐
mingyunxiaohai 2020-07-19
赵家小少爷 2020-07-04
chensen 2020-11-14
lwnylslwnyls 2020-11-06
ATenhong 2020-10-15
yanzhelee 2020-10-13
佛系程序员J 2020-10-10
guojin0 2020-10-08
佛系程序员J 2020-10-08
bluewelkin 2020-09-16
wwzaqw 2020-09-04
zhongdaowendao 2020-09-02
favouriter 2020-08-18
奎因amp华洛 2020-08-15
一青年 2020-08-13
千锋 2020-08-10
nangongyanya 2020-08-09
dongxurr 2020-08-08
明天你好 2020-08-03