Устанавливает тайм-аут, который срабатывает через 10 секунд, и, если щелчок не произошел, запускается часть too late
и очищается прослушиватель щелчков.
Кроме того, когда прослушиватель щелчков выполняется, очистите тайм-аут:
$('#response').on('click', function() {
var responseTime = myVid.currentTime;
var result;
if (responseTime < 5) {
console.log("too early");
} else {
console.log("correct");
}
clearTimeout(timeoutId);
console.log(result);
});
const timeoutId = setTimeout(() => {
console.log('too late');
$('#response').off('click');
}, 10000);
Если вы не хотите иметь жестко запрограммированное значение, во время которого прослушиваются щелчки, и всегда хотите, чтобы too late
доходило до конца видео, добавьте прослушиватель для события ended
вместо установки тайм-аута:
$('#response').on('click', function() {
var responseTime = myVid.currentTime;
var result;
if (responseTime < 5) {
console.log("too early");
} else {
console.log("correct");
}
});
$('#response').on('ended', () => {
console.log('too late');
$('#response').off('click');
});
Если вам также необходимо различать слишком поздний щелчок и вообще не нажимать, добавьте еще одно условие к проверке responseTime
. Живая демоверсия:
const myVid = $('video');
myVid[0].play();
let result;
$('#response').one('click', function() {
var responseTime = myVid[0].currentTime;
if (responseTime < 5) {
result = "too early";
} else if (responseTime < 8) {
result = "correct";
} else {
result = 'too late';
}
myVid.off('ended');
$('#response').prop('disabled', true);
});
myVid.one('ended', () => {
console.log('no response');
$('#response').off('click');
$('#response').prop('disabled', true);
});
setTimeout(() => {
console.log('End result:', result);
}, 12000);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div><button id="response">response - click here</button></div>
<video controls width="300" height="300">
<source src="https://i.temp.media/video/50-x-50-10.mp4" type="video/mp4">
</video>