zoukankan      html  css  js  c++  java
  • [Ramda] Eliminate Function Arguments (Point-Free Style) with Ramda's Converge

    When doing comparisons inside of functions, you end of relying heavily on the argument passed into the function. Ramda's converge allows you to do comparisons in a Point-Free style allowing you more flexibility with composing and constructing functions. This lesson walks through refactoring a function to Point-Free style using Ramda's Converge.

    For example we want to find the whether the first item of an array is the biggest number:

    const shouldBeTrue = [6, 3, 4, 5, 2, 1]
    const shouldBeFalse = [3, 4, 5, 2, 1]
    
    const isFirstBiggest = (xs) => xs[0] == xs.sort((a, b) => b - a)[0]
    
    console.log(isFirstBiggest(shouldBeTrue)) // true
    console.log(isFirstBiggest(shouldBeFalse)) // false

    In the code we can see this:

    const isFirstBiggest = (xs) => xs[0] === xs.sort((a, b) => b - a)[0]

    You can find that, param 'xs' appears both on the left and right side of euqals sign.

    If match this partten, we actually can use 'converge' from  Ramda.

    invoked, this new function is applied to some arguments, each branching function is applied to those same arguments. The results of each branching function are passed as arguments to the converging function to produce the return value.

    For example:

    const shouldBeTrue = [6, 3, 4, 5, 2, 1]
    const shouldBeFalse = [3, 4, 5, 2, 1]
    
    import {
      converge, equals, head, sort, descend, identity, compose
    }
    from 'ramda'
    
    const biggestNumberOfArray = compose(
      head,
      sort(descend(identity))
    );
    const isFirstBiggest = converge(
      equals, [
        head,
        biggestNumberOfArray
      ]
    );
    
    // xs =>
    //     xs[0] == xs.sort((a, b) => b - a)[0]
    
    
    
    console.log(isFirstBiggest(shouldBeTrue))
    console.log(isFirstBiggest(shouldBeFalse))

    So in the code:

    converge(
      equals, [
        head,
        biggestNumberOfArray
      ]
    )

    converge takes two params, first params is 'R.equals'. It tells what should do with the second param. Here is checking whether they are equal.

    Second param is an array, take tow expersions.

    R.head --> xs[0]
    biggestNumberOfArray --> xs.sort((a,b) => b-a)[0]

    More example:

    var average = R.converge(R.divide, [R.sum, R.length])
    average([1, 2, 3, 4, 5, 6, 7]) //=> 4
    
    var strangeConcat = R.converge(R.concat, [R.toUpper, R.toLower])
    strangeConcat("Yodel") //=> "YODELyodel"
  • 相关阅读:
    将SVD应用于推荐系统
    matrix.A
    机架感知配置
    PCA主成分分析进行数据降维
    Rabbitmq的高级特性
    Topics(主题模式)
    Routing(exchange--direct)
    fanout(Publish/Subscribe)发布/订阅
    Work Queues(工作队列)
    simple queue(简单队列)
  • 原文地址:https://www.cnblogs.com/Answer1215/p/6389410.html
Copyright © 2011-2022 走看看