判断数组是否相似 typeof instanceof

任务
请在index.html文件中,编写arraysSimilar函数,实现判断传入的两个数组是否相似。具体需求:
1. 数组中的成员类型相同,顺序可以不同。例如[1, true] 与 [false, 2]是相似的。
2. 数组的长度一致。
3. 类型的判断范围,需要区分:String, Boolean, Number, undefined, null, 函数,日期, window.
当以上全部满足,则返回"判定结果:通过",否则返回"判定结果:不通过"。

<!DOCTYPE HTML>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=gb18030">
    <title>判断数组是否相似</title>
</head>
<body>
    <script type="text/javascript">   
        /*
         * param1 Array 
         * param2 Array
         * return true or false
         */
        function arraysSimilar(arr1, arr2){
            if (!(arr1 instanceof Array) || !(arr2 instanceof Array)) {
                return false
            }
            if (arr1.length !== arr2.length) {
                return false
            }
            var TYPES = ['string', 'boolean', 'number', 'undefined', 'null', 'function', 'date', 'window'], 
            a1,
            a2,
            arr1TypesObj = {},
            arr2TypesObj = {}
            
            function whatType (ele) {
                var resultType;
                if (ele === null) {
                    resultType = 'null'
                } else if (ele === 'window') {
                    resultType = 'window'
                } else if (ele instanceof Array) {
                    resultType = 'array'
                } else if (ele instanceof Date) {
                    resultType = 'date'
                } else {
                    resultType = typeof ele
                }
                return resultType
            }
            
            for (var i = 0; i < arr1.length; i++) {
                a1 = whatType(arr1[i])
                a2 = whatType(arr2[i])
                if (arr1TypesObj[a1]) {
                    arr1TypesObj[a1] ++
                } else {
                    arr1TypesObj[a1] = 1
                }
                
                if (arr2TypesObj[a2]) {
                    arr2TypesObj[a2] ++
                } else {
                    arr2TypesObj[a2] = 1
                }
            }
            
            for(var i = 0, n = TYPES.length; i < n; i++) {
                if (arr1TypesObj[TYPES[i]] !== arr2TypesObj[TYPES[i]]) {
                    return false
                }
            }
            return true
        }
    </script>
</body>
</html>


-----------TEST-------------


var result=function(){
    //以下为多组测试数据
            var cases=[{
                    arr1:[1,true,null],
                    arr2:[null,false,100],
                    expect:true
                },{
                    arr1:[function(){},100],
                    arr2:[100,{}],
                    expect:false
                },{
                    arr1:[null,999],
                    arr2:[{},444],
                    expect:false
                },{
                    arr1:[window,1,true,new Date(),"hahaha",(function(){}),undefined],
                    arr2:[undefined,(function(){}),"okokok",new Date(),false,2,window],
                    expect:true
                },{
                    arr1:[new Date()],
                    arr2:[{}],
                    expect:false
                },{
                    arr1:[window],
                    arr2:[{}],
                    expect:false
                },{
                    arr1:[undefined,1],
                    arr2:[null,2],
                    expect:false
                },{
                    arr1:[new Object,new Object,new Object],
                    arr2:[{},{},null],
                    expect:false
                },{
                    arr1:null,
                    arr2:null,
                    expect:false
                },{
                    arr1:[],
                    arr2:undefined,
                    expect:false
                },{
                    arr1:"abc",
                    arr2:"cba",
                    expect:false
                }];
            
    //使用for循环, 通过arraysSimilar函数验证以上数据是否相似,如相似显示“通过”,否则"不通过",所以大家要完成arraysSimilar函数,具体要求,详见任务要求。    
            for(var i=0;i<cases.length;i++){
                if(arraysSimilar(cases[i].arr1,cases[i].arr2)!==cases[i].expect) {
                    document.write("不通过!case"+(i+1)+"不正确!arr1="+JSON.stringify(cases[i].arr1)+", arr2="+JSON.stringify(cases[i].arr2)+" 的判断结果不是"+cases[i].expect);
                    return false;
                }                
            }
            return true;
        }();
    document.write("判定结果:"+(result?"通过":"不通过"));

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值