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"
  • 相关阅读:
    三十七、Java基础之JDBC
    三十六、Java基础之File类
    各种IoC框架下实现AOP
    Eclipse导出可执行Jar文件(包含第三方Jar包)
    设计模式(Patterns in Java)-解道
    MyBatis入门示例
    freemarker实例2
    freemarker小例子
    MyEclipse8.6 破解以及注册码
    myeclipse中java文件中文注释乱码问题
  • 原文地址:https://www.cnblogs.com/Answer1215/p/6389410.html
Copyright © 2011-2022 走看看