JavaScript判断是否为数组

一、实例的构造函数属性constructor指向构造函数,那么通过constructor属性也可以判断是否为一个数组。例如:
在这里插入图片描述
实例化一个数组,他的构造函数为Array,我们通过constructor指向,可以判断当为true是,是数组,false,不是数组,除此之外,它还可与判断对象。但由于prototype是可以改变的,所有有一定的风险。

二、通过Object.prototype.toString.call来判断
在这里插入图片描述
在这里插入图片描述
可以将其封装成函数,后面好调用
三、instanceof运算符用于检验构造函数的prototype属性是否出现在对象的原型链中的任何位置,返回一个布尔值
在这里插入图片描述
四、通过Array.isArray判断

var arr = [1,2,3,4];
Array.isArray(arr);//true

五、例子:深度克隆
将数组判断封装成一个函数

 <script>
        function Judge(param){
            //返回值为[object Array]  Array
            return Object.prototype.toString.call(param).slice(8,-1);
        }
        // console.log(Judge([1,2,3,3]))
        function clone(param){
            var result;
            // 判断是否为数组
            if(Judge(param) == 'Array'){
                result = [];
                // 判断是否为对象
            } else if(Judge(param) == 'Object'){
                result = {};
            } else{
                return param;
            }
            // 遍历数组里的值
            for(var i in param){
                var value = param[i];
                console.log(value);
                // 判断当前值是否为数组
                if(Judge(value) === 'Array' || Judge(value) === 'Object'){
                    // 是数组就遍历里面的数
                    result[i] = clone(value);
                }else {
                    // 不是就直接赋值给result
                    result[i] = value;
                }
            }
            return result;  
        }
        var arr = [5,2,3,4,{
            a : 3,
            b : 2
        },2,3,4];
            var arr1 = clone(arr);
            arr[4].a = 10;
            console.log(arr);
            console.log(arr1);

        // console.log(clone(['1234',1,2,32,[1,2,3]]));
    </script>
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值