COCOS CREATOR(TS)之setTimeOut

一 : 前景

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

二 : 测试

Ⅰ,测试环境如下(使用TS代码)



Ⅱ,代码
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端

②微信IDE

③手机微信

2,setTimeOut自带参数

①WEB

②微信IDE

③手机微信

3,setTimeOut不自带参数

①WEB

②微信IDE

③手机微信

三:结论

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

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

原文地址:https://blog.51cto.com/aonaufly/2360953

时间: 2024-08-02 00:33:21

COCOS CREATOR(TS)之setTimeOut的相关文章

COCOS CREATOR(TS) 之HTTP通信

一 : XMLHttpRequest的封装 export class HttpCell{ private _xhr : XMLHttpRequest = null; private _server_url : string = null; private _callback : ( $isSucc : boolean , _http : HttpCell ,$data : any ) => void = null; private _timeout : number = null; privat

COCOS CREATOR(TS)之节点鼠标事件

一 : 前景 以官方的Demo为例子(HelloWorld)①-> UI层级结构②-> Canvas的属性 二 : 编码(Helloworld.ts) const {ccclass, property} = cc._decorator; @ccclass export default class Helloworld extends cc.Component { @property(cc.Label) label: cc.Label = null; @property text: string

COCOS CREATOR(TS)之按钮事件

一 : 前景介绍 为cc.Button添加事件的方法有很多种 , 本篇只讲解使用cc.Component.EventHandler的方法.因为此方案有一个最大的有点 : 可以获得cc.Event.EventTouch.但是此方案,相比如控件拖动方案要复杂一些,所以给出此Blog予以详解 二 : 详解 Ⅰ: 构建cc.Component.EventHandler对象 export class ClickEvent2CreatTool{ private static _instance : Clic

COCOS CREATOR(TS)之SrollBar的基本修改

一 : 前言 初始化的ScrollBar如下:看到这个的时候 , 我有几点一下感悟 :① -> 我觉得scrollBar(滚动条)很丑 , 而且我不需要滚动条② -> 我我的背景不错 , but我还是希望是透明的 , 以看到底层的棕色背景这就是需要修改原(官方)ScrollBar的地方,之所以作出如上的修改需求,是因为在Game中,大部分这样的界面,都不需要滚动条和背景 . 当然特殊的除外(比如聊天,可能需要一个) 二 : 修改 Ⅰ ,移除滚动条① -> 选择ScrollView节点(N

Cocos Creator 脚本模板

1.由于新建Cocos Creator脚本带有很多注释,并且有时候需要增加定制的默认注释,所以需要修改脚本生成模板. 2.在CocosCreator\resources\static\template目录下,找到new-script.js/new-script.ts并进行修改.

在 Cocos Creator 中使用 Protobufjs(一)

一. 环境准备 我一直在探索Cocos H5正确的开发姿势,目前做javascript项目已经离不开 nodejs.npm或grunt等脚手架工具了. 1.初始化package.json文件 npm init 当新建好cocos-js或creator项目,在项目根目录使用npm init命令,一路回车,将在当前目录创建package.json文件用于nodejs三方模块的管理.关于npm的使用细节网络上有很多教程,在此不用细说. 2. protobufjs模块 本人最早在cocos2dx 2.x

cocos creator主程入门教程(一)—— 初识creator

四邑隐侠,本名关健昌,10年游戏生涯,现隐居四邑.本系列文章以TypeScript为介绍语言. 我们在cocos creator新建一个Hello TypeScript项目,都会有一个assets/Scene/helloworld.fire文件.使用cocos creator开发游戏时,项目可以只有一个.fire文件.一般地,我会把这个文件夹改名为assets/scene,下面只有main.fire文件:assets/scene/main.fire. 双击main.fire文件,在层级管理器可以

cocos Creator js 房卡麻将/血战/H5四川麻将源码下载搭建

房卡麻将/血战/H5四川麻将 源码 支持iOS/Android/H5 完整源码 1.基于NODEJS+MYSQL的服务器,成熟的技术方案,高效稳定,且方便Windows开发,Linux平台布署,节约服务器运转成本. 2.采用最新版本的cocos引擎,cocos creator开发,可快速的进行界面调整.且能够快速地发布iOS,Android版本. 3.如需H5版本,只需针对H5平台进行资源优化即可. 4.成熟可靠的房卡式设计,能满足大部分用户使用体验. 5.产品经过大量测试,可以运转稳定. 测试

cocos creator随笔

接触一个月cocos creator做个笔记... 1.socket.io 封装了websocket , Ajax等,故任何浏览器都可以使用socket.io建立异步连接.websocket 双向需要握手建立连接,http 单向. 短连接:一次性交换数据,如登入,创建角色等  长连接:推送 (一) socket.emit('tell one person'); socket.broadcast.emit('tell to everyone'); socket.on('I heard',funct