温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

COCOS CREATOR(TS)之setTimeOut

发布时间:2020-06-23 12:09:53 来源:网络 阅读:1478 作者:Aonaufly 栏目:开发技术

一 : 前景

有很多前端可能觉得setTimeOut不值得一讲,But,在不同的平台setTimeOut的执行是有一定的规则需要遵守,有时也叫迫于无奈.比如,前几日的开发中发现一个非常奇怪的现象 , 就是setOutTime在Web / 微信IDE端都是可以起作用的 , 但是一旦到了手机微信中运行,好似就不那么灵光了.今日抽了点时间好好测试了一番 , 内容如下:

二 : 测试

Ⅰ,测试环境如下(使用TS代码)
COCOS CREATOR(TS)之setTimeOut
COCOS CREATOR(TS)之setTimeOut
COCOS CREATOR(TS)之setTimeOut
Ⅱ,代码
1,测试思想
分别给出有参数(setTimeOut自带传参和setTimeOut不自带) , 无参数在Web( edge ) , 微信IDE , 手机微信中查看各自的结果(打印数据)
2,代码
①,三种情况的枚举代码

export enum TY_SETTIMEOUT {
    /**setTimeOut 不自带参数*/
    ___HAS_PARAMS_UNBRING4ALONG___ = 1,
    /**不用传参*/
    ___NO_PARAMS___ = 2,
    /**setTimeOut 自带参数*/
    ___HAS_PARAMS_BRING4ALONG___ = 3
}

②,核心测试代码

private _myName : string = null;
    private _myAge : number = null;
    /**
     * 在微信端测试
     */
    private testSetTimeOutInWeChat( $ty : TY_SETTIMEOUT ) : void{
        switch ($ty) {
            case TY_SETTIMEOUT.___NO_PARAMS___:
                this._timeout_id = setTimeout(
                    this.onTimeOutNoParams.bind(this),
                    2000
                );
                break;
            case TY_SETTIMEOUT.___HAS_PARAMS_UNBRING4ALONG___:
                this._myName = "Aonaufly";
                this._myAge = 18;
                this._timeout_id = setTimeout(
                    this.onTimeOutHasParams_2_unbring.bind(this),
                    2000
                );
                break;
            case TY_SETTIMEOUT.___HAS_PARAMS_BRING4ALONG___:
                this._timeout_id = setTimeout(
                    this.onTimeOutHasParams_2_bring.bind(this),
                    2000,
                    "Aonaufly",
                    18
                );
                break;
        }
    }
    private onTimeOutNoParams() : void {
        console.log( ` no params timeout 结束 ------` );
    }

    private onTimeOutHasParams_2_bring( $name : string , $age : number ) : void{
        console.log(`has params timeout 自带参数 结束 ------ , name : ${$name} , age : ${$age}`);
    }

    private onTimeOutHasParams_2_unbring() : void{
        console.log(`has params timeout 不自带参数 结束 ------ , name : ${this._myName} , age : ${this._myAge}`);
    }

Ⅲ,测试

1,不带参数.

①WEB端
COCOS CREATOR(TS)之setTimeOut
②微信IDE
COCOS CREATOR(TS)之setTimeOut
③手机微信
COCOS CREATOR(TS)之setTimeOut

2,setTimeOut自带参数

①WEB
COCOS CREATOR(TS)之setTimeOut

②微信IDE
COCOS CREATOR(TS)之setTimeOut
③手机微信
COCOS CREATOR(TS)之setTimeOut

3,setTimeOut不自带参数

①WEB
COCOS CREATOR(TS)之setTimeOut
②微信IDE
COCOS CREATOR(TS)之setTimeOut
③手机微信
COCOS CREATOR(TS)之setTimeOut

三:结论

手机微信端是个报错的坑 , 注意不要让setTimeOut自带参数.如下
~~ this._timeout_id = setTimeout(
this.onTimeOutHasParams_2_bring.bind(this),
2000,
"Aonaufly",
18
);

                            其实在egret中没有这个问题 , egret封装了setTimeOut (egret.setTimeOut) .但是在LayaBox 和 Cocos Creator中就有这个问题.
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI