Laya Handler

不管是开发游戏还是其他应用或者Web,经常会使用到异步方法,使用异步函数的时候需要有回调函数。
比如JS中回调函数的使用

        var callFunc = function(){
            console.log('我是回调函数')
        }
        setTimeout(callFunc, 1000);

Laya中将回调函数封装在Handler中。并通过对象池统一管理。

Handler(事件处理器)

Handler是Laya中的事件处理类,在Laya中加载资源回调,动画播放回调等都是通过Handler。



Handler类的API也很简单,4个属性,6个方法。

Properties

  • method 回调方法的方法名。
  • args 回到方法的执行域。
  • caller 回调方法的参数,数组格式。
  • once 回调方式是否只执行一次,如果只执行一次,执行结束后自动回收到对象池。

Methods

  • create 从对象池中创建一个Handler对象。默认只会执行一次,执行结束放回对象池。
  • setTo 设置一个Handler对象的属性值。
    (这里我很好奇为什么不能单独设置某一个属性的值,需要同时设置4个属性的值)。
  • run 无参的方式执行回调函数。
  • runWith 带参的方式执行回调函数,只有一个参数直接传入,多个参数需要组合成数组传入。
  • clear 清理Handler对象的属性值。
  • recover 清理Handler对象的属性值并放回对象池。

示例代码

  • 无参的回调函数
                // 一定不要 new Handler,通过create创建Hander
        const handler = Laya.Handler.create(this,()=>{
            console.log("无参的回调函数")
        });
        handler.run();

create方法源码

    Handler.create=function(caller,method,args,once){
        (once===void 0)&& (once=true);
        if (Handler._pool.length)return Handler._pool.pop().setTo(caller,method,args,once);
        return new Handler(caller,method,args,once);
    }

可以看到创建时首先判断对象池是否为空,为空时才会new Handler。如果我们通过new Handler的方式创建对象池会一直增加,可能造成内存溢出。

  • 有参数的回调函数
        handler.setTo(this,(param_0,param_1)=>{
            console.log('参数:' + param_0);
            console.log('参数2:' + param_1);
        },['第一个参数','第二个参数'],false);

        handler.run();
  • 带参数的方式执行带参数的回调方法
    首先看下runWith方法的源码
/**
    *执行处理器,并携带额外数据。
    *@param data 附加的回调数据,可以是单数据或者Array(作为多参)。
    */
    __proto.runWith=function(data){
        if (this.method==null)return null;
        var id=this._id;
        if (data==null)
            var result=this.method.apply(this.caller,this.args);
        else if (!this.args && !data.unshift)result=this.method.call(this.caller,data);
                // 如果回到方法带参且通过runWith执行,则将两组参数拼接
        else if (this.args)result=this.method.apply(this.caller,this.args.concat(data));
        else result=this.method.apply(this.caller,data);  
                // 执行结束后将handler对象放回对象池
        this._id===id && this.once && this.recover();
        return result;
    }
        handler.setTo(this,(param_0,param_1,param_2)=>{
            console.log('参数:' + param_0);
            console.log('参数2:' + param_1);
            console.log('参数3:' + param_2);
        },['第一个参数','第二个参数'],false);

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

推荐阅读更多精彩内容

  • 你生命中所发生的一切,都是你吸引来的。它们是被你心中所保持的‘心相’吸引而来,它们就是你所想的。 有关于...
    A00精致女人阅读 201评论 0 0
  • 2018.6.25 我们决定出来旅游一下 先开车从昆明到重庆,魏先生有一个很好的朋友在重庆上班。 我们当天是下午6...
    小菠萝的日常阅读 148评论 0 0
  • 作者:苑文章 不用吆喝,不用走街串巷。只需在村头架上那买爆米花的黝黑的炉子,并生上火。那一声“嘭——嘭——”就是最...
    稼轩李德智阅读 690评论 0 1