等待 5 秒,然后执行下一行
2022-08-29 23:05:31
						下面的这个函数不像我想要的那样工作;作为一个JS新手,我不知道为什么。
我需要它等待5秒钟,然后再检查是否是.newState-1
目前,它不会等待,它只是立即检查。
function stateChange(newState) {
  setTimeout('', 5000);
  if(newState == -1) {
    alert('VIDEO HAS STOPPED');
  }
}
						下面的这个函数不像我想要的那样工作;作为一个JS新手,我不知道为什么。
我需要它等待5秒钟,然后再检查是否是.newState-1
目前,它不会等待,它只是立即检查。
function stateChange(newState) {
  setTimeout('', 5000);
  if(newState == -1) {
    alert('VIDEO HAS STOPPED');
  }
}
						您必须将代码放在您提供给的回调函数中:setTimeout
function stateChange(newState) {
    setTimeout(function () {
        if (newState == -1) {
            alert('VIDEO HAS STOPPED');
        }
    }, 5000);
}
任何其他代码将立即执行。
下面是使用新的异步/等待语法的解决方案。
请务必检查浏览器支持,因为这是 ECMAScript 6 中引入的语言功能。
实用功能:
const delay = ms => new Promise(res => setTimeout(res, ms));
用法:
const yourFunction = async () => {
  await delay(5000);
  console.log("Waited 5s");
  await delay(5000);
  console.log("Waited an additional 5s");
};
此方法的优点是,它使代码的外观和行为类似于同步代码。
Node.js 16 提供了一个基于 promise 的内置版本,因此我们不必创建自己的实用程序函数:setTimeout
import { setTimeout } from "timers/promises";
const yourFunction = async () => {
  await setTimeout(5000);
  console.log("Waited 5s");
  await setTimeout(5000);
  console.log("Waited an additional 5s");
};
⚠️ 只是为了记录,您可能想使用等待函数来规避争用条件(例如,在测试异步代码时)。这很少是一个好主意。