鱼C论坛

 找回密码
 立即注册
查看: 2566|回复: 2

[已解决]要写一个计数方法,有多个事件需要调用。

[复制链接]
发表于 2019-12-23 15:50:38 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
记录触发次数,做一个简单判断
这个例子是判断事件,被触发两次之后 执行一个方法;这里按的是每两次执行一次
方法如下:

var times = 1 ; //为了记录次数定义了一个常量;
~
~
//录屏分享的触发限制
    lupingOverXianzhi(){
        if(times%2 == 0){
            console.log("点击次数:"+times+"");
            console.log("触发录屏分享");
            GameConfig.androidSend.lupingOver();//这一行是当条件触发时调用这个方法,不必深究
            times +=1;
        }else{
            console.log("点击次数:"+times+"");
            times +=1;
        }

    }
这是 在 cocos creator 脚本里加的,大致原理和 js 是一样。

遇到的问题是 多个事件 调用 这个方法,方法 内置 的 计数器(tims)成为公用的,一个事件触发第一次是1.第二个事件触发的第一次就是成了 2。

本来是想写一个 方法 然后每个事件独立调用这个这个方法记录触发的次数;
事件A触发了 九次 ,times =9;
此时 事件 B 触发发了一次 , times = 1;

我觉的可能是我想的太简单。希望有大佬帮助。


最佳答案
2019-12-24 08:41:03
用对象实例的方式解决
function getObj() {
   return {
      times: 1, //为了记录次数定义了一个常量;

      //录屏分享的触发限制
      lupingOverXianzhi() {
         if (this.times % 2 == 0) {
            console.log("点击次数:" + this.times + "");
            console.log("触发录屏分享");
            GameConfig.androidSend.lupingOver();//这一行是当条件触发时调用这个方法,不必深究
         } else {
            console.log("点击次数:" + this.times + "");
         }
         this.times += 1;
      }
   }
}

// A事件
let eventObjA = getObj();

// XX节点.on('XX事件', eventObjA.lupingOverXianzhi);

// B事件
let eventObjB = getObj();
// XX节点.on('XX事件', eventObjB.lupingOverXianzhi);

注意事件函数绑定时的this指向问题
这个生成对象的方式比较粗糙,你可以写成类,用new去实例化一个对出来
像你这种属性值根据情况不同而不同,且多个不同值不冲突,但数据处理函数是相同的,就是用对象实例的方式解决,生成对象的方式有很多,就看你怎么实现
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-12-24 08:41:03 | 显示全部楼层    本楼为最佳答案   
用对象实例的方式解决
function getObj() {
   return {
      times: 1, //为了记录次数定义了一个常量;

      //录屏分享的触发限制
      lupingOverXianzhi() {
         if (this.times % 2 == 0) {
            console.log("点击次数:" + this.times + "");
            console.log("触发录屏分享");
            GameConfig.androidSend.lupingOver();//这一行是当条件触发时调用这个方法,不必深究
         } else {
            console.log("点击次数:" + this.times + "");
         }
         this.times += 1;
      }
   }
}

// A事件
let eventObjA = getObj();

// XX节点.on('XX事件', eventObjA.lupingOverXianzhi);

// B事件
let eventObjB = getObj();
// XX节点.on('XX事件', eventObjB.lupingOverXianzhi);

注意事件函数绑定时的this指向问题
这个生成对象的方式比较粗糙,你可以写成类,用new去实例化一个对出来
像你这种属性值根据情况不同而不同,且多个不同值不冲突,但数据处理函数是相同的,就是用对象实例的方式解决,生成对象的方式有很多,就看你怎么实现
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-12-24 09:23:26 | 显示全部楼层
陈立希2570 发表于 2019-12-24 08:41
用对象实例的方式解决
function getObj() {
   return {

感谢大佬,我去试试
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-23 10:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表