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
  • 相关阅读:
    *1408素数回文数的个数
    *1406单词替换
    1404我家的门牌号
    1402Vigenère密码(Noip2012提高组第1题)
    1401机器翻译(Noip2010提高组第1题)
    AcWing
    模板
    The 2019 Asia Nanchang First Round Online Programming Contest
    模板
    模板
  • 原文地址:https://www.cnblogs.com/Answer1215/p/6195461.html
Copyright © 2011-2022 走看看