zoukankan      html  css  js  c++  java
  • [Transducer] Create a Sequence Helper to Transduce Without Changing Collection Types

    A frequent use case when transducing is to apply a transformation to items without changing the type of the collection.

    In this lesson, we'll create a helper to do just that. seq will be similar to into, except the target type will be inferred from the source collection. For example, if transducing from an array, seq will create an array as the output collection as well.

    seq is thus more restrictive and easier to consume than into.

    The whole for 'seq' is we don't need to worry about collection type will different from target type. In short, input and output are the same type.

    import {isPlainObject} from 'lodash';
    import {compose, map, arrayReducer, objectReducer, transduce} from '../utils.js';
    
    const into = (to, xf, collection) => {
      if (Array.isArray(to)) return transduce(xf, arrayReducer, to, collection);
      else if (isPlainObject(to)) return transduce(xf, objectReducer, to, collection);
      throw new Error('into only supports arrays and objects as `to`');
    };
    
    const seq = (xf, collection) => {
      if (Array.isArray(collection)) return transduce(xf, arrayReducer, [], collection);
      else if (isPlainObject(collection)) return transduce(xf, objectReducer, {}, collection);
      throw new Error('unsupported collection type');
    };
    
    seq(map(x => x*2), [1,2,3]);
    
    const flip = compose(
      map(([k,v]) => ({[v*10]:k})),
    );
    
    seq(flip, {one: 1, two: 2, three: 3});
  • 相关阅读:
    删除旧版vue-cli
    vue.extend和vue.component的区别
    vue-loader处理vue文件
    CentOS7安装iptables防火墙
    java类的初始化顺序
    java的接口和抽象类的理解
    js中的in操作符
    js中call和apply函数
    js的类型转换
    闭包作用
  • 原文地址:https://www.cnblogs.com/Answer1215/p/8305920.html
Copyright © 2011-2022 走看看