zoukankan      html  css  js  c++  java
  • [Javascript Crocks] Compose Functions for Reusability with the Maybe Type

    We can dot-chain our way to great success with an instance of Maybe, but there are probably cases where you need to apply the same series of transformations against different Maybes. In this lesson, we’ll look at some point-free versions of some common Maybe methods and see how we can compose them together to get a reusable function that can be applied to any Maybe instance.

    We are going to rewrite the following code by using function composion:

    const crocks = require('crocks');
    const {and, isString, Maybe, prop, safe, option, map, alt, chain} = crocks;
    const {not, isEmpty, compose, converge, join, split, toLower} = require('ramda');
    
    ///////////////UTILS/////////////////
    const joinKey = compose(join('_'),  split(' '), toLower);
    const isNotEmpty = compose(
        not,
        isEmpty
    )
    const isNonEmptyString = and(isNotEmpty, isString);
    /*const isNonEmptyString = R.converge(
        R.and,
        [
            isNotEmpty,
            isString
        ]
    );*/
    
    const createUrl = key =>`https://egghead.io/articles/${joinKey(key)}`;
    
    ////////////////MAIN////////////////
    
    const article = {
         id: 1,
         name: 'Learn FP with this one weird trick'
    };
    
    /*
    const getUrl = obj =>
        prop('name', obj) // Maybe(string)
            .chain(safe(isNonEmptyString)) // Maybe(string) --safe(isNonEmptyString)--> Maybe(Maybe(String)) --chain--> Maybe(String)
            .alt(Maybe.of('Nope')) // Nothing -> Just('Nope')
            .map(createUrl)
            .option('default');
      */
     
    const getSafeName = compose(
        chain(safe(isNonEmptyString)),
        prop('name')
    );
    const getUrlOrDefault = compose(
        option('Not valid URL'),
        map(createUrl)
    );
    const getUrl = compose(
        getUrlOrDefault,
        getSafeName
    );
    const getUrlOrNope = compose(
        getUrlOrDefault,
        alt(Maybe.of('Nope')),
        getSafeName
    ) 
    const res = getUrl(article);
    console.log(res);   
  • 相关阅读:
    深浅拷贝的区别
    python 连接mysql数据库
    前端 之HTML基础
    MySQL 多键
    MySQL 存储引擎 字段类型 约束条件
    MySQL数据库的基础知识
    全局解释器和协程
    进程剩余部分和线程
    计算机网络体系结构整理-第三单元网络交换
    计算机网络体系结构整理-第二单元IP技术
  • 原文地址:https://www.cnblogs.com/Answer1215/p/9037945.html
Copyright © 2011-2022 走看看