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('李四'));//1forEach()方法
用于遍历指定数组
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
lwnylslwnyls 2020-11-06
yanzhelee 2020-10-13
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