首页 > 解决方案 > 满足条件时只执行一次 if 语句

问题描述

我有这样的功能:

function foundGold(ptX, ptY) {
  var gridX = Math.floor(ptX / 36);
  var gridY = Math.floor(ptY / 36);
  if(mapArray[gridY][gridX] == 3) {
    return true;
  }
}

if(foundGold(boatPosX + 36, boatPosY)) { goldAmount+= 1; gold.innerHTML = goldAmount; }

它检查我的游戏角色位置,如果它踩到数组的某个部分,则意味着条件为真并且函数继续运行。所以在这种情况下,我检查另一个函数是否foundGold为真,如果是,给用户一些金币。问题是,当条件为真时,玩家将继续获得无穷无尽的金币,除非他离开该位置并且条件不再为真。

现在我该如何做到这一点,即使用户一直站在一个地方并且条件一直为真,他也不会继续获得金币并且该功能只会执行一次,无论条件为真多长时间?

我不想在条件为真时一直添加+=1goldAmount只添加一次。一次运行或类似的事情后是否可以退出它?

标签: javascriptif-statementbooleanconditional

解决方案


如果您不想修改原始数组,可以将信息存储在其他位置。如果它只用在一个函数中,我会把它存储在函数本身上。由于您使用的是原语,因此您可以轻松地将其展平为单个键,并结合 playerId:

function foundGold( ptX, ptY, playerId ) {

    const gridX = Math.floor( ptX / 36 );
    const gridY = Math.floor( ptY / 36 );

    if ( mapArray[ gridY ][ gridX ] === 3 ) {

        // Gold exists; check if player already found it
        const key = `_memory;${playerId};${gridX};${gridY}`;
        if ( this[ key ] ) return false;
        this[ key ] = true;

        return true;

    }

    return false;

}

或者,您可以拥有一个 3 维数组。


推荐阅读