• [JS Compose] 1. Refactor imperative code to a single composed expression using Box


    After understanding how Box is, then we are going to see how to use Box to refacotr code, to un-nested expression.

    For example, we have code:

    const moneyToFloat = str => {
      const cost = str.replace(/$/g, '');
      return parseFloat(cost);
    }
    
    const percentToFloat = str => {
      const cost = parseFloat(str.replace(/$/g, ''));return cost * 0.01;
    }
    
    const applyDiscount = (price, prec) => {
      const cost = moneyToFloat(price);
      const p = percentToFloat(prec);
      return cost - cost * p;
    }
    
    const result = applyDiscount('$5.00', '20%')
    console.log(result) // 4

    So how it would be when we using Box version:

    const moneyToFloat = str => {
      const cost = str.replace(/$/g, '');
      return parseFloat(cost);
    }
    
    const moneyToFloat = str => 
      Box(str)
      .map(s => s.replace(/$/g, ''))
      .map(s => parseFloat(cost))

    Well, nothing really impress here, we put 'str' into Box, and using map to do all the logic.

    const percentToFloat = str => {
      const cost = parseFloat(str.replace(/$/g, ''));
      return cost * 0.01;
    }
    
    const percentToFloat = str => 
      Box(str.replace(/$/g, ''))
        .map(s => parseFloat(s))
        .map(s => s * 0.01)

    This part, notice we un-nest 'parseFloat(str.replace(...))', make logic more readable by using map.

    const applyDiscount = (price, prec) => {
      const cost = moneyToFloat(price);
      const p = percentToFloat(prec);
      return cost - cost * p;
    }
    
    const applyDiscount = (price, prec) =>
      moneyToFloat(price)
        .fold(cost => percentToFloat(prec)
             .fold(p => cost - cost * p))

    Notice here, because 'moneyToFloat' return a Box, so we are able to chain map on that.

    And 'cost', we can use clouse to remember 'cost', and chain 'fold' on precentToFloat. The reason we use 'fold' instead of 'map', is 'fold' we can get value out of Box.

    const Box = x =>
    ({
      map: f => Box(f(x)),
      fold: f => f(x),
      toString: () => `Box(${x})`
    })
    
    const moneyToFloat = str => 
      Box(str)
      .map(s => s.replace(/$/g, ''))
      .map(s => parseFloat(cost));
    
    const percentToFloat = str => 
      Box(str.replace(/$/g, ''))
        .map(s => parseFloat(s))
        .map(s => s * 0.01);
    
    const applyDiscount = (price, prec) =>
      moneyToFloat(price)
        .fold(cost => percentToFloat(prec)
             .fold(p => cost - cost * p))
    
    const result = applyDiscount('$5.00', '20%')
    console.log(result) // 4
  • 相关阅读:
    Docker+Jenkins更换国内插件源
    招聘java工程师
    Apache seaTunnel 数据集成平台
    DBeaver连接MySQL问题的解决
    iphone的mov文件复制到电脑的方法
    IDEA中RestfulToolkit插件的安装及使用
    lwm2m 的notify 的机制
    ALI云接入学习
    CAT1 UIS8910模组对接阿里云平台
    任务的堆栈究竟有何魔力
  • 原文地址:https://www.cnblogs.com/Answer1215/p/6161182.html
Copyright © 2020-2023  润新知