javascript检测两个数组是否相似


Posted in Javascript onMay 19, 2015

JS要比较两个数组是否有相同的元素,即两个数组所有元素都相同,但元素的顺序不一定一致。只就需要先将数组进行排序,再比较两个数组是否相等。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
  <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
  <title>js 检测两个数组是否相似</title>
</head>
<body>
  <script>
    //数组中的成员类型相同,顺序可以不同。例如[1, true] 与 [false, 2]是相似的。
     //数组的长度一致。
    //类型的判断范围,需要区分:String, Boolean, Number, undefined, null, 函数,日期, window.
    function arraysSimilar(arr1, arr2){
      //判断边界
      if (!(arr1 instanceof Array) || !(arr2 instanceof Array)) {
        return false;
      }

      //判断长度
      if (arr1.length != arr2.length) return false;

      var i = 0, n = arr1.length, countMap1 = {}, countMap2 = {}, t1, t2, TYPES = ['string', 'boolean', 'number', 'undefined', null, 'function', 'date', 'window'];

      for ( ; i < n; i++) {
        t1 = typeOf(arr1[i]);
        t2 = typeOf(arr2[i]);
        if (countMap1[t1]) {
          countMap1[t1] ++;
        }else{
          countMap1[t1] = 1;
        }
        if (countMap2[t2]) {
          countMap2[t2] ++;
        }else{
          countMap2[t2] = 1;
        }
      }

      function typeOf(ele){
        var r;
        if (ele === null) r = 'null';
        else if(ele instanceof Array) r = 'array';
        else if(ele === window) r = 'window';
        else if(ele instanceof Date) r = 'date';
        else r = typeof ele;
        return r;

      }

      for (i = 0; i < TYPES.length; i++) {
        if (countMap1[TYPES[i]] != countMap2[TYPES[i]]) return false;
      }

      return true;
    }

    document.write(arraysSimilar([1,true], [false, 2]));
  </script>
</body>
</html>

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
jquery 表单取值常用代码
Dec 22 Javascript
javascript温习的一些笔记 基础常用知识小结
Jun 22 Javascript
jQuery 翻牌或百叶窗效果(内容三秒自动切换)
Jun 14 Javascript
AngularJS入门教程(一):静态模板
Dec 06 Javascript
Javascript 拖拽雏形中的一些问题(逐行分析代码,让你轻松了拖拽的原理)
Jan 23 Javascript
JS实现在网页中弹出一个输入框的方法
Mar 03 Javascript
JS实现支持Ajax验证的表单插件
Mar 24 Javascript
jQGrid Table操作列中点击【操作】按钮弹出按钮层的实现代码
Dec 05 Javascript
Angular中的$watch方法详解
Sep 18 Javascript
Vue.js递归组件构建树形菜单
Dec 24 Javascript
vue组件传递对象中实现单向绑定的示例
Feb 28 Javascript
javascript 数组(list)添加/删除的实现
Dec 17 Javascript
10条建议帮助你创建更好的jQuery插件
May 18 #Javascript
原生js实现的贪吃蛇网页版游戏完整实例
May 18 #Javascript
JQuery中层次选择器用法实例详解
May 18 #Javascript
Jquery中基本选择器用法实例详解
May 18 #Javascript
Jquery注册事件实现方法
May 18 #Javascript
jquery中map函数遍历数组用法实例
May 18 #Javascript
jquery使用each方法遍历json格式数据实例
May 18 #Javascript
You might like
打造计数器DIY三步曲(上)
2006/10/09 PHP
PHP Ajax实现页面无刷新发表评论
2007/01/02 PHP
PHP缓存技术的使用说明
2011/08/06 PHP
浅谈apache和nginx的rewrite的区别
2013/02/22 PHP
php empty()与isset()区别的详细介绍
2013/06/17 PHP
深入Nginx + PHP 缓存详解
2013/07/11 PHP
PHP判断一个gif图片是否为动态图片的方法
2014/11/19 PHP
Laravel4中的Validator验证扩展用法详解
2016/07/26 PHP
php版阿里大于(阿里大鱼)短信发送实例详解
2016/11/30 PHP
Laravel 5.4重新登录实现跳转到登录前页面的原理和方法
2017/07/13 PHP
jQuery 名称冲突的解决方法
2011/04/08 Javascript
jQuery怎么解析Json字符串(Json格式/Json对象)
2013/08/09 Javascript
js 中的switch表达式使用示例
2020/06/03 Javascript
Jquery仿IGoogle实现可拖动窗口示例代码
2014/08/22 Javascript
js的[defer]和[async]属性
2014/11/24 Javascript
js正则表达式匹配数字字母下划线等
2015/04/14 Javascript
Bootstrap每天必学之媒体对象
2015/11/30 Javascript
详解AngularJS中的http拦截
2016/02/09 Javascript
jQuery javascript获得网页的高度与宽度的实现代码
2016/04/26 Javascript
在Swiper内如何制作CSS3动画效果示例代码
2017/12/07 Javascript
详解react-router 4.0 下服务器如何配合BrowserRouter
2017/12/29 Javascript
Vue中多元素过渡特效的解决方案
2020/02/05 Javascript
TF-IDF与余弦相似性的应用(一) 自动提取关键词
2017/12/21 Python
python利用requests库进行接口测试的方法详解
2018/07/06 Python
vue.js实现输入框输入值内容实时响应变化示例
2018/07/07 Python
tensorflow实现简单逻辑回归
2018/09/07 Python
Python从Excel中读取日期一列的方法
2018/11/28 Python
python使用magic模块进行文件类型识别方法
2018/12/08 Python
python爬虫调度器用法及实例代码
2020/11/30 Python
do you have any Best Practice for testing
2016/06/04 面试题
servlet面试题
2012/08/20 面试题
小学教师培训感言
2014/02/11 职场文书
2015年毕业生自荐信范文
2015/03/24 职场文书
煤矿安全生产工作总结
2015/08/13 职场文书
Python实战之疫苗研发情况可视化
2021/05/18 Python
Python 如何实现文件自动去重
2021/06/02 Python