Время, которое пользователь печатает, равно нулю, хотя в javascript оно должно быть больше.
Я пытаюсь рассчитать время с момента, когда пользователь начинает печатать, до момента, когда он останавливается. Я поставил две переменные start и end и вычел их друг из друга. Но он всегда возвращает ноль. Можете ли вы также дать простой способ расчета wpm, если это возможно? Я хочу, в конце концов, рассчитать количество слов в минуту, когда пользователь правильно набирает 10 слов. Так что мне нужно время от того, когда они начали, когда они завершили подсказку.
Спасибо!
Javascript:
var input = document.getElementById("boch");
input.addEventListener("keyup", function (event) {
if (event.keyCode === 13) {
event.preventDefault();
document.getElementById("bocho").click();
}
});
var element = document.querySelector("#boch");
element.onkeyup = function () {
var value = element.value;
if (value.includes("m")) {
var start = Date.now();
}
if (value.includes("man")) {
document.getElementById('word-1').style.backgroundColor = 'green';
} else {
document.getElementById('word-1').style.backgroundColor = "red";
}
if (value.includes("man become")) {
document.getElementById('word-2').style.backgroundColor = 'green';
} else {
document.getElementById('word-2').style.backgroundColor = "red";
}
if (value.includes("man become as")) {
document.getElementById('word-3').style.backgroundColor = 'green';
} else {
document.getElementById('word-3').style.backgroundColor = "red";
}
if (value.includes("man become as and")) {
document.getElementById('word-4').style.backgroundColor = 'green';
} else {
document.getElementById('word-4').style.backgroundColor = "red";
}
if (value.includes("man become as and through")) {
document.getElementById('word-5').style.backgroundColor = 'green';
} else {
document.getElementById('word-5').style.backgroundColor = "red";
}
if (value.includes("man become as and through find")) {
document.getElementById('word-6').style.backgroundColor = 'green';
} else {
document.getElementById('word-6').style.backgroundColor = "red";
}
if (value.includes("man become as and through find would")) {
document.getElementById('word-7').style.backgroundColor = 'green';
} else {
document.getElementById('word-7').style.backgroundColor = "red";
}
if (value.includes("man become as and through find would here")) {
document.getElementById('word-8').style.backgroundColor = 'green';
} else {
document.getElementById('word-8').style.backgroundColor = "red";
}
if (value.includes("man become as and through find would here and")) {
document.getElementById('word-9').style.backgroundColor = 'green';
} else {
document.getElementById('word-9').style.backgroundColor = "red";
}
if (value.includes("man become as and through find would here and before")) {
document.getElementById('word-10').style.backgroundColor = 'green';
} else {
document.getElementById('word-10').style.backgroundColor = "red";
}
if (value.includes("man become as and through find would here and before")) {
var end = Date.now();
}
let millis = end-start;
console.log(millis)
}
HTML:
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>repl.it</title>
<link href="style.css" rel="stylesheet" type="text/css" />
</head>
<h1>
<span id="word-1">man</span> <span id="word-2">become</span> <span id="word-3">as</span>
<span id="word-4">and</span> <span id="word-5">through</span> <span id="word-6">find</span> <span id="word-7">would</span> <span id="word-8">here</span> <span id="word-9">and</span> <span id="word-10">before</span>
</h1>
<input type="text" id="boch" autocomplete="off">
</div>
<div id="typing-area">
<button id="bocho" onclick="document.getElementById('boch').value = ''">Enter</button>
</html>
<script src="main.js"></script>```
1 ответ
Прежде всего,
value.includes("m")
истинно каждый раз, поэтому таймер перезапускается каждый раз, когда функция запускается. Вместо этого используйте
value === "m"
:
if (value === "m") {
start = Date.now();
}
Вам нужно объявить
var end
а также
var start
за пределами
if
оператор и установите его внутри:
var start;
if (value === "m") {
start = Date.now();
}
// other code...
var end;
if (value.includes("man become as and through find would here and before")) {
end = Date.now();
}
let millis = end-start;
Кроме того, я рекомендую ставить пробел между
end
а также
start
.
end-start
может быть именем переменной.