去重的6种方法!

  1. //1.filter:(indexOf)方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素, filter() 不会对空数组进行检测。 filter() 不会改变原始数组。

  2. var arr1 = [7, 7, 7, 8, 8, 8, 82, 82, 839, 49, 329, 8, 3, 3];

  3. var arr1_1 = arr1.filter(function(m, n) {

  4. return arr1.indexOf(m) == n;

  5. })

  6. document.write(arr1_1 + "<br />");

  7.  
  8. //2.map:(push indexOf)把每个元素通过函数传递到当前匹配集合中,生成包含返回值的新的 jQuery 对象。

  9. var arr2 = [7, 7, 7, 8, 8, 8, 82, 82, 839, 49, 329, 8, 3, 3];

  10. var arr2_2 = [];

  11. arr2.map(function(m, n) {

  12. if(arr2.indexOf(arr2[n]) == n) {

  13. arr2_2.push(m);

  14. }

  15. });

  16. document.write(arr2_2 + "<br />");

  17.  
  18. //3.indexOf(push)搜索数组中的元素,并返回它所在的位置。

  19. var arr3 = [7, 7, 7, 8, 8, 8, 82, 82, 839, 49, 329, 8, 3, 3];

  20. var arr3_3 = [];

  21. for(var i = 0; i < arr3.length; i++) {

  22. if(arr3_3.indexOf(arr3[i]) == -1) {

  23. arr3_3.push(arr3[i]);

  24. }

  25. }

  26. document.write(arr3_3 + "<br />");

  27.  
  28. //4.splice对数组进行删除、插入、替换,是最强大的数组方法。改变原数组

  29. var arr4 = [7, 7, 7, 8, 8, 8, 82, 82, 839, 49, 329, 8, 3, 3];

  30. for(var i = 0; i < arr4.length; i++) {

  31. for(var j = i + 1; j < arr4.length; j++) {

  32. if(arr4[i] == arr4[j]) {

  33. arr4.splice(j, 1)

  34. j--; //别忘记减

  35. }

  36. }

  37. }

  38. document.write(arr4 + "<br />");

  39.  
  40. //5.push(数组去重一一对比)添加到数组末尾

  41. var arr5 = [7, 7, 7, 8, 8, 8, 82, 82, 839, 49, 329, 8, 3, 3];

  42.  
  43. function remm(arr) {

  44. var arr5_5 = [];

  45. for(var i = 0; i < arr5.length; i++) {

  46. for(var j = 0; j < arr5.length; j++) {

  47. if(arr5[i] == arr5_5[j]) {

  48. break;

  49. }

  50. }

  51. if(arr5[i] != arr5_5[j]) {

  52. arr5_5.push(arr5[i]);

  53. }

  54. }

  55. return arr5_5;

  56. }

  57. document.write(remm(arr5) + "<br />");

  58. //6.set数据结构Set类似于数组,但是成员的值都是唯一的,没有重复的值。用set.size表示伪数组长度

  59. var arr6= [7, 7, 7, 8, 8, 8, 82, 82, 839, 49, 329, 8, 3, 3];

  60.  
  61. var set = new Set(arr6);

  62. var newArr = new Array(...set);

  63. document.write(newArr+"<br />");

  64. </script>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值