[XState] Invoke Child XState Machines from a Parent Machine

Posted answer1215

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[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: {},
  },
})

 

以上是关于[XState] Invoke Child XState Machines from a Parent Machine的主要内容,如果未能解决你的问题,请参考以下文章

XState:在没有中间状态的情况下链接多个 Promise

将事件发送到 XState 中的子服务数组

Cross-Site Trace(XST) 跨站式追踪***

XState 不会停留在空闲状态

[XState] Track Infinite States with with XState Context

关于时间:UTC/GMT/xST/ xDT