zoukankan      html  css  js  c++  java
  • js小知识-数组去重

    查看zepto源码时,看到它的数组去重写法非常简单。下面是代码

    var uq = function(array){
    
     return [].filter.call(array,function(item,idx){
           return array.indexOf(item) == idx
      })
    }

    uq([1,3,5,1,2,5])
    输出: [1,3,5,2]

     这里用到了array filter方法。

    下面再简单介绍一下 filter方法的使用。

    filter() 方法创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。

    function isBigEnough(value) {
      return value >= 10;
    }
    
    var filtered = [12, 5, 8, 130, 44].filter(isBigEnough);
    
    // filtered is [12, 130, 44]
    
    // ES6 way
    
    const isBigEnough = value => value >= 10;
    
    let [...spraed]= [12, 5, 8, 130, 44];
    
    let filtered = spraed.filter(isBigEnough);
    
    // filtered is [12, 130, 44]

    语法

    var new_array = arr.filter(callback[, thisArg])

    参数

    callback
    用来测试数组的每个元素的函数。调用时使用参数 (element, index, array)。
    返回true表示保留该元素(通过测试),false则不保留。
    thisArg
    可选。执行 callback 时的用于 this 的值。

    返回值

          一个新的通过测试的元素的集合的数组

    描述

    filter 为数组中的每个元素调用一次 callback 函数,并利用所有使得 callback 返回 true 或 等价于 true 的值 的元素创建一个新数组。callback 只会在已经赋值的索引上被调用,对于那些已经被删除或者从未被赋值的索引不会被调用。那些没有通过 callback 测试的元素会被跳过,不会被包含在新数组中。

    callback 被调用时传入三个参数:

    1. 元素的值
    2. 元素的索引
    3. 被遍历的数组

    如果为 filter 提供一个 thisArg 参数,则它会被作为 callback 被调用时的 this 值。否则,callback 的 this 值在非严格模式下将是全局对象,严格模式下为 undefined
    The thisvalue ultimately observable by callback is determined according to the usual rules for determining thethis seen by a function.

    filter 不会改变原数组。

    filter 遍历的元素范围在第一次调用 callback 之前就已经确定了。在调用 filter 之后被添加到数组中的元素不会被 filter 遍历到。如果已经存在的元素被改变了,则他们传入 callback 的值是 filter 遍历到它们那一刻的值。被删除或从来未被赋值的元素不会被遍历到。

    示例

    例子:筛选排除掉所有的小值

    下例使用 filter 创建了一个新数组,该数组的元素由原数组中值大于 10 的元素组成。

    function isBigEnough(element) {
      return element >= 10;
    }
    var filtered = [12, 5, 8, 130, 44].filter(isBigEnough);
    // filtered is [12, 130, 44]
  • 相关阅读:
    Linux内存、Swap、Cache、Buffer详细解析
    深入浅出前端本地储存
    Javscript字符串常用方法总结
    Python优雅日志记录器-Loguru
    Flume推送数据到SparkStreaming案例实战和内幕源码解密
    SparkStreaming数据源Flume实际案例分享
    基于HDFS的SparkStreaming案例实战和内幕源码解密
    Scala和Java二种方式实战Spark Streaming开发
    StreamingContext、DStream、Receiver深度剖析
    案例动手实战并在电光石火间理解其工作原理
  • 原文地址:https://www.cnblogs.com/zhouyangla/p/7457035.html
Copyright © 2011-2022 走看看