04.异步转换

开始读这篇文章之前,你应该已经熟悉了状态机生命周期事件

有时,你需要在状态转换期间执行一些异步代码,并确保在代码完成之前不会进入新的状态。这方面一个很好的例子是:当你离开一个状态并逐渐淡出UI组件时,或者将其从屏幕上滑出,并且在动画完成之前不想转换到下一个状态

你可以通过从任意生命周期事件中返回一个Promise对象来实现。

从生命周期事件返回一个Promise将导致转换动作的生命周期暂停。它可以通过解决Promise来继续,或拒绝Promise来取消转换动作。

例如(使用jQuery效果):

  var fsm = new StateMachine({

    init: 'menu',

    transitions: [
      { name: 'play', from: 'menu', to: 'game' },
      { name: 'quit', from: 'game', to: 'menu' }
    ],

    methods: {

      onEnterMenu: function() {
        return new Promise(function(resolve, reject) {
          $('#menu').fadeIn('fast', resolve)
        })
      },

      onEnterGame: function() {
        return new Promise(function(resolve, reject) {
          $('#game').fadeIn('fast', resolve)
        })
      },

      onLeaveMenu: function() {
        return new Promise(function(resolve, reject) {
          $('#menu').fadeOut('fast', resolve)
        })
      },

      onLeaveGame: function() {
        return new Promise(function(resolve, reject) {
          $('#game').fadeOut('fast', resolve)
        })
      }
    }

  })

确保始终有解决(或拒绝)Promise,否则状态机将永远卡在这个未确定的转换中。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 有限状态机的库 安装 在浏览器中: 下载源码[dist/state-machine.js] 或 压缩版[dist/...
    Pilihou阅读 524评论 0 0
  • Next.js 是一个轻量级的 React 服务端渲染应用框架。 Next.js中文站点 http://nextj...
    前端妹子ice阅读 72,700评论 6 19
  • 状态机是由一组状态(states), 如: solid liquid gas 和一套转换动作(transition...
    Pilihou阅读 360评论 0 0
  • React 起源于 Facebook 的内部项目,他从最早的UI引擎变成了一整套前后端通吃的 Web App 解决...
    三也视界阅读 1,651评论 0 4
  • 一、Vue原理:4部分: 1.通过document.createDocumentFragment()创建虚拟dom...
    战神七小姐阅读 393评论 0 0