zoukankan      html  css  js  c++  java
  • [XState] Invoke Child XState Machines from a Parent Machine

    Trying to structure the state logic of an application as a single machine can begin to become unwieldy when we have too many states. It is often better to divide our app into smaller machines and invoke those machines as necessary.

    When we enter a state in a machine, we can invoke a child machine. This machine can send and receive events from the parent. When the child machine reaches a final state, the onDone transition is taken by the parent's current state node.

    To invoke a child machine, we use the invoke property and set the src property to a machine. We can forward events in the parent machine to the child machine by setting the property autoForwards to true. We can also send events to the child machine through setting the second argument of the send() function to { to: 'child-machine-id' }.

    The child machine can send events to the parent machine by using the sendParent function. In this way, parent and child machines can communicate.

    const childMachine = Machine({
      id: 'child',
      initial: 'step1',
      states: {
        step1: {
          on: { STEP: 'step2' },
        },
        step2: {
          on: { STEP: 'step3' },
        },
        step3: {
          type: 'final',
        }
      }
    })
      
    const parentMachine = Machine({
      id: 'parent',
      initial: 'idle',
      states: {
        idle: {
          on: { ACTIVATE: 'active' },
        },
        active: {
          invoke: {
            id: 'child',
            src: childMachine,
            onDone: 'done',
          },
          on: {
            STEP: {
              actions: send('STEP', { to: 'child' }),
            },
          },
        },
        done: {},
      },
    })
  • 相关阅读:
    VueCLI3如何更改安装时的包管理器
    查天气43课-46课
    【Python第31课到42课】
    【Python第16课到30课 】
    Python笔记
    【AC】九度OJ题目1153:括号匹配问题
    【AC】九度OJ题目1436:Repair the Wall
    【WA】九度OJ题目1435:迷瘴
    Matlab图片改颜色通道不改名存储
    [Linux 操作] awk操作の 打印图片路径
  • 原文地址:https://www.cnblogs.com/Answer1215/p/12225792.html
Copyright © 2011-2022 走看看