js数组方法

 一、检测数组方法

       console.log(arr instanceof Array); //true       主要是判断某个实例(arr)是否属于某个对象。

       console.log(arr.constructor == Array); //true   判断实例(arr)的构造函数是否等于某个对象。

       console.log(Array.isArray(arr)); //true         ES5新增数组方法,判断数组是不是数组。

       console.log(Object.getPrototypeOf(arr) == Array.prototype); //true    Object.getPrototypeOf()方法返回指定对象的原型,然后和Array的原型对比。

        console.log(Array.prototype.isPrototypeOf(arr)); //true               Array.prototype表示Array的构造函数的原型;isPrototypeOf()方法可以判断一个对象是否存在于另一个对象的原型链上。

        console.log(Object.prototype.toString.call(arr) == '[object Array]'); //true    把对象转化成字符串和一个已知的对象进行对比。 

        二、非数组转数组的方法

         1、伪书组转数组    [ ].slice.call(obj)   Array.from(obj)   拓展运算符

         2、字符串转数组    

        console.log(str.split(''));

        console.log([...str]);

        console.log(Array.from(str)); 

         3、对象转数组  

         console.log(Object.keys(obj));

         console.log(Object.values(obj));

         console.log(Object.entries(obj)); 

         三、数组内置方法

        1、增

        arr.unshift(4)//前加

        arr.push(4)//后加

        arr=arr1.concat(arr2) //合并

        2、减

        arr.shift()//前删

        arr.pop()//后删

        arr.splice("删除项下标"//开始的位置,"删除个数") //挑着删

        arr=arr.slice(开始的位置,结束的位置) //挑着删

        3、改

        (1)、改变顺序

         arr.reverse()

         arr.sort(a,b=>{b-a})

        (2)、 多维转一维

        reduce+递归  

        (3)、  性质改变

        数组->字符串   arr=arr.toString()   arr=arr.join()

         数组转对象     arr=new Set(arr)

        (4)去重

        arr=[...new Set(arr)]

        4、查

        查看符合条件的状态

        console.log(arr.every(item=>{})); //false  同真为真

        console.log(arr.some(item=>{}));  //false 一真为真

        console.log(arr.includes(1));  //true

        console.log(arr.map(item=>{return item==1})); //[true, false, false, false]

        查看符合条件的项

        console.log(arr.filter(function (item, index) {return item > 1;}));

        console.log(arr.find(item=>{return item>2}));//1

        查看符合条件的项的下标

        console.log(arr.indexOf(item=>{}));//-1

        console.log(arr.findIndex(item=>{return item>2}));//-1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值