zoukankan      html  css  js  c++  java
  • [Compose] 10. Capture Side Effects in a Task

    We examine the data structure Task, see some constructors, familiar methods, and finally how it captures side effects through laziness.

    We using a 'data.task' library. It is a bit similar to $q library in Angular. Accepts one function, function takes two params, 'reject function' & 'resolve function'. 

    import Task from 'data.task';
    
    
    const launchMissiles = () =>
      new Task((rej, res) => {
        console.log('launch missiles!')
        res('missile')
      })

    Because this is laziness, therefore, we can compose logic based on that:

    const app = launchMissiles().map(x => x + '!')
    app
    .map(x => x + '!')
    .fork(e => console.error('err', e),
          x => console.log('success', x))

    If inside 'lauchMissiles' call 'reject' function, all the map function chaining on app won't be called anymore.

    'fork' is the actually function which trigger it works.

    -----

    import Task from 'data.task';
    
    
    const launchMissiles = () =>
      new Task((rej, res) => {
        console.log('launch missiles!')
        res('missile')
      })
    
    const app = launchMissiles().map(x => x + '!')
    
    app
    .map(x => x + '!')
    .fork(e => console.error('err', e),
          x => console.log('success', x))
    
    //launch missiles!
    success
  • 相关阅读:
    ln 命令使用
    python 调用浏览器方法
    Git新手必备常用命令
    Spring 整合 Hibernate 入门
    看看什么是Guice
    maven 详解,其它这几篇文章也不错
    shell编程中date用法(转)
    通过scp实现vps控制没有外网IP的localhost
    centos6.6安装python2.7
    Cygwin配置
  • 原文地址:https://www.cnblogs.com/Answer1215/p/6195461.html
Copyright © 2011-2022 走看看