最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • javascript-state-machine教程10:状态机工厂

    正文概述 掘金(pilihou)   2021-06-08   766

    状态机工厂

    本文档中的大多数示例构造单个状态机实例,例如:

      var fsm = new StateMachine({
        init: 'solid',
        transitions: [
          { name: 'melt',     from: 'solid',  to: 'liquid' },
          { name: 'freeze',   from: 'liquid', to: 'solid'  },
          { name: 'vaporize', from: 'liquid', to: 'gas'    },
          { name: 'condense', from: 'gas',    to: 'liquid' }
        ]
      });
    

    如果希望使用相同的配置构造多个实例,则应该使用状态机工厂。状态机工厂提供了一个js构造函数(例如:class),它可以多次实例化:

      var Matter = StateMachine.factory({     //  <-- the factory is constructed here
          init: 'solid',
          transitions: [
            { name: 'melt',     from: 'solid',  to: 'liquid' },
            { name: 'freeze',   from: 'liquid', to: 'solid'  },
            { name: 'vaporize', from: 'liquid', to: 'gas'    },
            { name: 'condense', from: 'gas',    to: 'liquid' }
          ]
      });
    
      var a = new Matter(),    //  <-- instances are constructed here
          b = new Matter(),
          c = new Matter();
    
      b.melt();
      c.melt();
      c.vaporize();
    
      a.state;    // solid
      b.state;    // liquid
      c.state;    // gas
    

    使用工厂,每个状态机实例都是唯一的js对象。每个实例都管理自己的state属性,但是方法通过普通的js原型机制共享。

    将状态机行为应用于现有对象

    有时可能希望将状态机行为应用于已经存在的对象(例如,React组件)。可以通过StateMachine.apply方法来完成:

      var component = { /* ... */ };
    
      StateMachine.apply(component, {
        init: 'A',
        transitions: {
          { name: 'step', from: 'A', to: 'B' }
        }
      });
    

    将状态机工厂行为应用于现有类

    还可以将状态机工厂行为应用于现有类,但必须通过在类构造函数方法中调用this._fsm()来初始化:

      function Person(name) {
        this.name = name;
        this._fsm(); //  <-- IMPORTANT
      }
    
      Person.prototype = {
        speak: function() {
          console.log('my name is ' + this.name + ' and I am ' + this.state);
        }
      }
    
      StateMachine.factory(Person, {
        init: 'idle',
        transitions: {
          { name: 'sleep', from: 'idle',     to: 'sleeping' },
          { name: 'wake',  from: 'sleeping', to: 'idle'     }
        }
      });
    
      var amy = new Person('amy'),
          bob = new Person('bob');
    
      bob.sleep();
    
      amy.state;   // 'idle'
      bob.state;   // 'sleeping'
    
      amy.speak(); // 'my name is amy and I am idle'
      bob.speak(); // 'my name is bob and I am sleeping'
    

    起源地下载网 » javascript-state-machine教程10:状态机工厂

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元