实现三元运算符会创建无限循环



这是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()

这是索引.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

我使用这个简单程序的目标是不断输出问题,直到用户正确为止。如果用户答对了问题,您将控制台.log("您赢了!"(,程序将停止运行。我在三元运算符的帮助下做到了这一点。但是,为什么我的程序永远运行?

checkAnswer总是返回未定义,因为你没有return任何内容:

Question.prototype.checkAnswer=function(answer) {
return answer==this.correct
}

最新更新