• [XState] Multiple Simultaneous States with Parallel States


    Can you walk and talk at the same time? If so, you've experienced what it's like to be in two states at the same time. Hopefully, those two states have no influence on the other. Whether or not you talk, you can walk, and vice versa. States that occur concurrently and have no affect on the other are known as "parallel states".

    Parallel states happen simultaneously. The machine is in all of the parallel states at the same time. To create a parallel state node, we set the type to 'parallel' and then remove the initial state. There's no need for an initial property when you're in all the child states at the same time.

    const { Machine } = require("xstate");
    
    const spaceHeaterMachine = Machine({
      id: "spaceHeater",
      initial: "poweredOff",
      states: {
        poweredOff: {
          on: { TOGGLE_POWER: "poweredOn" }
        },
        poweredOn: {
          on: { TOGGLE_POWER: "poweredOff" },
          type: "parallel", // mark parallel
          states: {
            heated: {
              initial: "lowHeat",
              states: {
                lowHeat: {
                  on: { TOGGLE_HEAT: "highHeat" }
                },
                highHeat: {
                  on: { TOGGLE_HEAT: "lowHeat" }
                }
              }
            },
            oscillation: {
              initial: "disabled",
              states: {
                disabled: {
                  on: { TOGGLE_OSC: "enabled" }
                },
                enabled: {
                  on: { TOGGLE_OSC: "disabled" }
                }
              }
            }
          }
        }
      }
    });

  • 相关阅读:
    二进制、八进制、十进制、十六进制的转换
    loadrunner-检查点
    loadrunner-集合点
    loadrunner-事务
    软件测试分类总结
    《黑客与画家》读后感
    说两个我在工作中有价值的bug
    HTTP状态码
    Android开发学习——android与服务器端数据交互
    Android开发学习——Volley框架
  • 原文地址:https://www.cnblogs.com/Answer1215/p/12216235.html
Copyright © 2020-2023  润新知