zoukankan      html  css  js  c++  java
  • Array的 filter() 和 sort()

    filter()

    filter() 方法创建一个创建一个新数组,新数组中的元素是通过筛选原数组中的元素所得到的。筛选的方式是把传入的函数依次作用于每个元素,然后根据返回值是true还是false决定保留还是丢弃该元素。

    filter() 方法不会对空数组进行检查。

    语法:

     Array.filter(function(currentValue, index, arr), thisValue)

    参数:

    示例:

    一、去除数组中的空白字符

    var arr = ['  ', 'I', 'Love', '	', '
    ', 'you'];
    var f = function(currentValue) {
        return currentValue.trim();
    }
    console.log(arr.filter(f));    //[ 'I', 'Love', 'you' ]

    二、数组去重

    var arr = [1, '1', '1', 2, 2, 5];
    var f = function(currentValue, index, arr) {
        return arr.indexOf(currentValue) === index ? true : false;
    }
    console.log(arr.filter(f));    //[ 1, '1', 2, 5 ]

     sort()

    sort() 方法用原地算法对数组的元素进行排序,并返回排序后原数组的引用。排序算法是稳定的,默认按照字符串的Unicode码进行排序。

     语法:

    arr.sort([compareFunction])

    参数:

    compareFunction:可选,用于按某种顺序进行排列的函数。该函数接收两个参数,即第一个和第二个用于比较的元素。如果未指定该参数,则默认会把数组元素当作字符串进行比较。

    示例:

    一、对数组进行倒序排序

    var arr = [1, 5, 9 , 8, 6, 3];
    var compareFunction = function(firstEl, secondeEl) {
        if (firstEl > secondeEl)
            return -1;
        if (firstEl < secondeEl)
            return 1;
        return 0;
    };
    arr.sort(compareFunction);
    console.log(arr);    // [ 9, 8, 6, 5, 3, 1 ]

    二、忽略大小写,对字符数组进行排序

    var arr = ['Google', 'apple', 'Microsoft'];
    var compareFunction = function(firstEl, secondeEl) {
    
        if (firstEl.toUpperCase() < secondeEl.toUpperCase())
            return -1;
        if (firstEl.toUpperCase() > secondeEl.toUpperCase())
            return 1;
        return 0;
    };
    console.log(arr.sort(compareFunction));    // [ 'apple', 'Google', 'Microsoft' ]
  • 相关阅读:
    DataAdapter的Fill方法(转)
    C#读取xml节点数据方法小结
    Service-Oriented Architecture,SOA(转)
    SOAP详解(转)
    WebService到底是什么?(转)
    只需要2个工具,百度云盘大文件就能用迅雷和IDM下载
    刘铁猛-深入浅出WPF-系列资源汇总
    WCF书籍
    书籍:wpf学习书籍介绍
    在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器(转)
  • 原文地址:https://www.cnblogs.com/huwt/p/10726272.html
Copyright © 2011-2022 走看看