• [Javascript Crocks] Flatten Nested Maybes with `chain`


    Sometimes, we run into situations where we end up with a Maybe within the context of another Maybe. Nested structures like this can get really confusing to work with. In this lesson, we’ll look at an example of this and see how chaincan help us out by flattening the nested Maybe

    As we all know, inside an array return another array is nested array.

    Inside observable return another observable get Observable of Observable.

    The same inside Just return another Just, we get Just of Just:

    const prop = require('crocks/Maybe/prop');
    const propPath = require('crocks/Maybe/propPath');
    
    /**
     * return Maybe type
     */
    const getUser = id =>
        new Promise((resolve, reject) => {
            const result = {
                status: 200,
                body: {
                    id: 1,
                    username: 'tester',
                    email: 'test@gmail.com',
                    address: {
                        street: '111 E. West St',
                        city: 'Anywhere',
                        state: 'PA',
                        postalCode: '19123-4567'
                    }
                }
            }
            resolve(prop('body', result)); // return Just {}
        });
    
    
    const getPostalCode = propPath(['address', 'postalCode']); 
    
    getUser(1)
        .then(user => user.map(getPostalCode)) // map to Just {} --> Just Just '19123-4567'
        .then(console.log); // Just Just "19123-4567"

    Inside getUser function we return a Just type object. Then from propPath, we get Just Just type object. That's why we need flatten it.

    The way to solve the problem is using flat map which is called 'chain' in Crocks.

    getUser(1)
        .then(user => user.chain(getPostalCode).option("not available")) 
        .then(console.log); // "19123-4567"
  • 相关阅读:
    数学杂谈 #22
    Windows 下查看端口占用情况
    [转] VUE 的常用指令2
    [转] VUE 的常用指令
    26种sourcemap看花了眼?别急,理解这几个全弄懂
    [转] webpack 中的 loader
    [转] VUE 的常用指令3
    [转]VUE 之 Webpack 打包构建
    [转]VUE devTools 安装方法
    [转] webpack devtool 配置之 Source Map
  • 原文地址:https://www.cnblogs.com/Answer1215/p/9026521.html
Copyright © 2020-2023  润新知