数组里面常用的一些方法总结

push()数组尾部添加
pop()数组尾部删除
shift()数组头部删除
unshift()数组头部添加
reverse() 反转数组、
concat() 连接接数组 arr = arr1.concat(arr2)
slice(start,end)数组截取
arr.splice(index , howmany , item1,…,itemX) Array.splice(开始位置, 删除的个数(添加),元素)
arr.splice(index , howmany)截取制定元素howmany不为0
arr.splice(index , howmany,item1,…,itemX)替换制定元素howmany不为0
arr.splice(index , howmany,item1,…,itemX)添加制定元素howmany为0
array.indexOf(item,start) 查找制定元素的位置

forEach():对数组进行遍历循环,这个方法没有返回值。语法:array.forEach(function(currentValue , index , arr){//do something}, thisValue)

let arr = [1, 2, 3, 4, 5]
   num.forEach(x => x*2)
   // arr = [2, 4, 6, 8, 10]  原来的数组直接改变

map():指“映射”,方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。

    let arr = [1, 2, 3, 4, 5]
    let newArr = arr.map(x => x*2)
    //arr= [1, 2, 3, 4, 5]   原数组保持不变
    //newArr = [2, 4, 6, 8, 10] 有返回值

array.filter(function(currentValue , index , arr){//do something}, thisValue) 筛选出满足条件的值
es6新方法
arr = Array.from(json)转化为数组
Array.of(1,9) ([1,9])把一组数值转化为数组
find()查询 返回true或fasle
findIndex ()返回索引
array.copyWithin(target , start , end)拷贝数组指定元素

数组转化为对象

var list = {};
var arr = ["123","456","789"];
for (var key in arr) {
    list[key] = arr[key];
}

对象转化为数组

Object.values()属性值变为数组
Object.keys()属性名变为数组
Object.entries()键值对变为数组

var arr = []
for (let i in obj) {
    arr.push(i); //属性
    //arr.push(obj[i]); //值
}
console.log(arr);
键值对
var arr = []
for (let i in obj) {
    let o = {};
    o[i] = obj[i];
    arr.push(o)
}
console.log(arr);

猜你喜欢

转载自blog.csdn.net/liangkaihuaen/article/details/99694431