zoukankan      html  css  js  c++  java
  • [Javascript Crocks] Recover from a Nothing with the `coalesce` Method

    The alt method allows us to recover from a nothing with a default Maybe, but sometimes our recovery efforts might need to enlist some logic to recover properly. In this lesson, we’ll see how we can use the coalesce method on the Maybe to recover from a Nothing by calling a function.

    When one would like to option a Maybe but would like to remain within a Maybe type, coalesce can be used. coalesce expects (2) functions for it's inputs.

    The first function is used when invoked on a Nothing and will return a Justinstance wrapping the result of the function. The second function is used when coalesce is invoked on a Just and is used to map the original value, returning a new Just instance wrapping the result of the second function.

    Difference between 'coalesce' & 'alt' is that: 

     'alt' returns just a hardcoded value;

     'coalesce' is more dynamice, based on some condition, you can return different values.

    The use case of 'coalesce' is similar to 'alt', but instead wrting two function as 'alt' does:

    const getArticleName = obj => prop('name', obj)
        .chain(safe(isNonEmptyString)) // If return Nothing then use alt value
        .alt(Maybe.of('page not found'));
    
    const getArticleUrl = obj => getArticleName(obj)
        .map(createUrlFromName)
        .option('default');
    
    const url = getArticleUrl(article);

    In 'coalesce', we just combine in one single function:

    const getArticleUrl = obj => prop('name', obj)
        .chain(safe(isNonEmptyString)) // If return Nothing then use first function of coalesce
        .coalesce(() => 'page not found', createUrlFromName)
        .option('default');
    
    const url = getArticleUrl(article);
    const crocks = require('crocks')
    const { identity ,and, compose, isEmpty, isString, Maybe, not, prop, safe } = crocks
    const { join, split, toLower } = require('ramda')
    
    
    const article = {
        id: 1,
        _name: 'Learning crocksjs functional programming library'
    };
    
    const createUrlSlug = compose(join('-'), split(' '), toLower);
    const createUrl = slug => `https://egghead.io/articles/${slug}`;
    const createUrlFromName = compose(createUrl, createUrlSlug);
    const isNonEmptyString = and(not(isEmpty), isString);
    
    
    const getArticleUrl = obj => prop('name', obj)
        .chain(safe(isNonEmptyString)) // If return Nothing then use first function of coalesce
        .coalesce(() => 'page not found', createUrlFromName)
        .option('default');
    
    const url = getArticleUrl(article);
    
    console.log(url)
  • 相关阅读:
    flex布局
    input框不能输入问题
    JS的innerHTML完成注册表
    CSS的z-index属性和box-shadow属性
    JS个人笔记
    css照片墙
    透明度设置
    a标签的name属性
    iframe标签
    title属性
  • 原文地址:https://www.cnblogs.com/Answer1215/p/9037633.html
Copyright © 2011-2022 走看看