JavaScript - How to Wait / SetTimeOut / Sleep / Delay

廉价感情. 提交于 2019-12-21 02:00:25

问题


This again is my Rock Paper Scissors game.

At present state the user can't see what's happening because after being prompted for input(Rock, Paper or Scissors) they are immediately reprompted.

The question is how can I make the program delay such that they at least can read what's going on.

I've read that sleep() does not exist in JavaScript. I'm trying to use setTimeOut however, the setTimeOut is causing the program to not run.

Any ideas on how I can delay the next user input after the first user input. This can be done via any JS solution.

This is my present code

function playUntil(rounds) {
        var playerWins = 0;
        var computerWins = 0;
        setTimeout(function() {
        while ((playerWins < rounds) && (computerWins < rounds)) {
          var computerMove = getComputerMove();
          var winner = getWinner(playerMove, computerMove);
          console.log('The player has chosen ' + playerMove + '. The computer has chosen ' + computerMove);
          if (winner === "Player") {
              playerWins += 1; 
          } 
          else if (winner === "Computer") {
              computerWins += 1;
          } 
          if ((playerWins == rounds) || (computerWins == rounds)) {
              console.log("The game is over! The " + winner + " has taken out the game!");
              console.log("The final score was Player - [" + playerWins + "] to Computer - [" + computerWins + "]");
          }
          else {
              console.log(winner + ' takes the round. It is now ' + playerWins + ' to ' + computerWins);
          }
          }
      return [playerWins, computerWins]
    ;},5000);
    }

回答1:


You cannot return a value for a parent function on a setTimeout, setInterval or another child function because have different scopes.

You can use promises instead: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise

Bad:

function x () {
  setTimeout(function () {
     return "anything";
  }, 5000);
}

Using promises:

function x () {
  return new Promise(function (resolve, reject) {
    setTimeout(function () {
      resolve("anything");
    }, 5000);
  });
}

Then you can call function like:

x()
.then(
  function (result) {
    alert(result); // Do anything.
  }
);

PD: I have bad English, I'm sorry!.




回答2:


This took me a long time to figure out but here was the solution.

Create this function

function sleep(miliseconds) {
    var currentTime = new Date().getTime();
    while (currentTime + miliseconds >= new Date().getTime()) {
    }
}

Add this into my code where I wanted the delay

sleep(3000)


来源:https://stackoverflow.com/questions/35544073/javascript-how-to-wait-settimeout-sleep-delay

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!