По крайней мере, я считать, что итерации останавливаются после первого цикла. Я пытаюсь заставить мой пароль зацикливаться 3 раза, когда вводится неправильный пароль перед отправкой сообщения об ошибке. Когда я ввожу один неверный пароль и нажимаю кнопку отправки, итерации прекращаются. Новичок в кодировании, поэтому, пожалуйста, дайте мне знать, если я делаю что-то не так.
Мой JS (функция кнопки on-click
):
var password = "password";
var notif = document.getElementById("notif");
var entryCount = 0;
var entryLimit = 3;
var error = false;
function inputPW(){
for(i = 0; i < 3; i++){
notif.innerHTML = "";
if(passwordInp.value === password){
notif.innerHTML = "You got it!";
break;
}
else if(i < 3){
notif.innerHTML = "Incorrect password. Please try again.";
}
else{
notif.innerHTML = "Password limits exceeded.";
}
}
}
Мой HTML (только тело):
<h1>Password Getter</h1>
<p>Password:</p>
<input id = "passwordInp" type="text" placeholder="Password" autofocus>
<button id="enterBtn" type="button" onclick="inputPW()">Submit</button>
<p id="notif"></p>
<script src="JSscript.js"></script>
К объектам документа @Cerceis, имеющим идентификатор, можно получить прямой доступ из DOM в javascript без getElementById. (устаревшая функция)
@mrtechtroid Я вижу, его все же следует избегать, поскольку он помечен как устаревший.
цикл for выполняет один и тот же код за один раз и не ждет ввода пользователя. поскольку ввод не изменился во время работы, он запускается только один раз. вместо этого вызывайте функцию, когда пользователь нажимает кнопку отправки, и увеличивайте глобальную переменную.
var password = "password";
var notif = document.getElementById("notif");
var passwordInp = document.getElementById("passwordInp");
var entryCount = 0;
var entryLimit = 3;
var error = false;
var i = 0;
function inputPW(){
notif.innerHTML = "";
if(passwordInp.value === password){
notif.innerHTML = "You got it!";
break;
else if(i < 3){
notif.innerHTML = "Incorrect password. Please try again.";
}
else{
notif.innerHTML = "Password limits exceeded.";
}
}
}
//these constants won't change during execution
const LIMIT = 3;
const PASSWORD = 'password';
let entryCount = 0; // a global variable
let authorized = true; //can we still try?
function handleInput(inp){
if(!authorized){
return; //we do nothing if we're not authorized anymore
}
const matches = inp == PASSWORD;
if(matches){
//do 'success' thing
} else if(entryCount < LIMIT){
entryCount++;
//do 'not success' thing
} else{
authorized = false;
//do 'unauthorized' thing
}
}
<h1>Password Getter</h1>
<p>Password:</p>
<input id = "passwordInp" type="text" placeholder="Password" autofocus>
<button id="enterBtn" type="button" onclick="handleClick(passwordInp.value)">Submit</button>
<p id="notif"></p>
<script src="JSscript.js"></script>
Я узнал о 5 вещах из этого блока кода. Огромное спасибо! :)
Откуда взялся passwordInp.value? Вы делаете его идентификатором для ввода, но он не определен в JS.