Это JS:
function Question(question, answers, correct) {
this.question=question;
this.answers=answers;
this.correct=correct;
}
Question.prototype.displayQuestion=function () {
console.log(this.question)
this.answers.forEach((answer, i)=> {
console.log(`${i}: ${answer}`)
})
}
Question.prototype.checkAnswer=function(answer) {
(answer==this.correct)? true: false
}
var q1=new Question("What day is it today?", ["Monday", "Tuesday"], 0)
var q2=new Question("How are you?", ["Good", "Really good"], 1)
var q3=new Question("Is it nice out?", ["Yes", "No", "In-between"], 3)
var questions=[q1, q2, q3];
function createGame() {
var num=Math.floor(Math.random()*questions.length)
questions[num].displayQuestion()
var userInput=parseInt(prompt("Please enter answer"))
questions[num].checkAnswer(userInput)? console.log('You won!'): createGame()
}
createGame()
Это index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Section 5: Advanced JavaScript: Objects and Functions</title>
</head>
<body>
<h1>Section 5: Advanced JavaScript: Objects and Functions</h1>
<script src="script.js"></script>
</body>
</html
Моя цель с этой простой программой состояла в том, чтобы продолжать выводить вопрос, пока пользователь не понял его правильно. Если пользователь правильно понял вопрос, вы бы запустили console.log («Вы выиграли!»), И программа перестала работать. Я сделал это с помощью троичных операторов. Однако почему моя программа работает вечно?