ReferenceError: ответ не определен в HTMLButtonElement.button.onclick

Я новичок в мире программирования и работаю над проектом в стиле викторины. Проблема, с которой я сталкиваюсь, заключается в следующем: "Uncaught ReferenceError: ответ не определен в HTMLButtonElement.button.onclick". Мой вопрос заключается в следующем: как ответы на мои вопросы не сохраняются при нажатии ответа и как лучше определить ответ в моем коде? Любая помощь будет принята с благодарностью.

HTML

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Trivia Game</title>

    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.2/css/bootstrap.min.css" />
    <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo"
        crossorigin="anonymous"></script>
    <link href="https://fonts.googleapis.com/css?family=Lora" rel="stylesheet">
    <link rel="stylesheet" type="text/css" href="assets/css/style.css" />
</head>

<body>
    <div class="grid">
        <div id="trivia">
            <h1>A Golfer's Trivia</h1>
            <!-- for question -->
            <div id="questionName">
                <p id="question"></p>
            </div>

            <p id="progress"></p>
            <!-- options for the questions -->
            <div class="buttons">
                <button id="btn0"><span id="option0"></span></button>
                <button id="btn1"><span id="option1"></span></button>
                <button id="btn2"><span id="option2"></span></button>
                <button id="btn3"><span id="option3"></span></button>
            </div>

            <div>
                <p id="timer"></p>
                <p id="show-clock"></p>
            </div>


            </div>
        </div>

    <script type="text/javascript" src="assets/javascript/game.js"></script>

</body>

    </html>``

JAVASCRIPT

// Keeping score

var unanswered = 0;
var questionIndex = 0;
var score = 0;
var questions = 0;
var answer;


function Quiz(questions) {
    this.score = 0;
    this.questions = questions;
    this.questionIndex = 0;
}
function getQuestionIndex() {
    return this.questions[this.questionIndex];
}

function endGame() {
    return this.questions.length === this.questionIndex;
}

function guess(answer) {

    if (this.getQuestionIndex() === correctAnswer(answer)) {
        this.score++;
    }
    this.questionIndex++;
}

// functions for questions

function Question(text, choices, answer) {
    this.text = text;
    this.choices = choices;
    this.answer = answer;
}

// check user answer
function correctAnswer(choice) {
    return choice === this.answer;
}

// have questions appear if game is still going
function populate() {

    console.log("populating");
    if (endGame()) {
        showScores();
    }
    else {
        var element = document.getElementById("question");
        element.innerHTML = getQuestionIndex().text;

        // have options appear for each question
        var choices = getQuestionIndex().choices;
        for (var i = 0; i < choices.length; i++) {
            var element = document.getElementById("option" + i);
            element.innerHTML = choices[i];
            guess("btn" + i, choices[i]);
        }
        showProgress()
    }
}

// store user guess
function guess(id) {
    var button = document.getElementById(id);
    button.onclick = function () {

        questionIndex++;
        populate();
        guess(answer);

    }
}
// show which question player is on
function showProgress() {
    var currentQuestionNumber = questionIndex + 1;
    var element = document.getElementById("progress");
    element.innerHTML = "Question " + currentQuestionNumber + " of " + questions.length;
}

// display scores at end of game
function showScores() {
    var gameOver = "<h1>Results</h1>" + "<h2 class='corr score'> Correct Answers: " + score + "<h2>" + "<br>" + "<h2 class = 'wrong score'>Wrong Answers: " + (questions.length - score) + "<h2 class = 'unanswered score'>Unanswered: " + "<h2>";
    var results = document.getElementById("trivia");
    results.innerHTML = gameOver;


}

// sets of questions, options, answers
var questions = [
    new Question("Where was the game of golf originally founded?",
        ["Scotland", "China", "England", "United States"],
        "Scotland"),
    new Question("Who is the only female golfer to make a cut at a PGA Tour event?",
        ["Michelle Wie", "Annika Sorensteim", "Lexi Thompson", "Babe Zaharias"],
        "Babe Zaharias"),
    new Question("What is the name for a hole-in-one on a par five?",
        ["Triple Eagle", "Double Ace", "Condor", "Albatross"],
        "Condor"),
    new Question("Who holds the record for the most PGA Tour victories?",
        ["Tiger Woods", "Jack Nicklaus", "Ben Hogan", "Sam Snead"],
        "Sam Snead"),
    new Question("What percentage of golfers will never achieve a handicap of 18 or less?",
        ["50 percent", "73 percent", "80 percent", "91 percent"],
        "80 percent"),
    new Question("How many dimples are on a standard regulation golf ball?",
        ["336", "402", "196", "468"],
        "336"),
    new Question("Who was considered the first professional golfer in history?",
        ["Bobby Jones", "Byron Nelson", "Walter Hagen", "Old Tom Morris"],
        "Walter Hagen"),
    new Question("Who is the youngest player to win the Masters?",
        ["Tiger Woods", "Jack Nicklaus", "Jordan Speith", "Arnold Palmer"],
        "Tiger Woods")
];


populate();


var intervalId;


$("#btn").on("click", run);

//  The run function sets an interval

function run() {
    clearInterval(intervalId);


}

var timeLeft = 10;
var displayClock = document.getElementById('timer');

var timerId = setInterval(countdown, 1000);

function countdown() {
    if (timeLeft === 0) {


        unanswered++;
        questionIndex++;
        populate();

        alert("You did not answer in time!");
        timeLeft = 10;

        // reset timer, pull question
        run();
    } else {
        displayClock.innerHTML = timeLeft + ' seconds remaining';
        timeLeft--;
    }
}

run();

1 ответ

Я полагаю, вы столкнулись с другой проблемой здесь. Вот две функции, снятые с вашего скрипта:

guess(any) версия 1

function guess(answer) {
    if (this.getQuestionIndex() === correctAnswer(answer)) {
        this.score++;
    }
    this.questionIndex++;
}

guess(any)версия 2

function guess(id) {
    var button = document.getElementById(id);
    button.onclick = function () {

        questionIndex++;
        populate();
        guess(answer);

    }
}

У вас есть 2 функции с именем guess(), Хотя имена обоих значений различаются, с точки зрения Javascript они оба выглядят так:

function guess(value){}

Как JS должен знать, кому из них вы собираетесь позвонить?

Переименуйте хотя бы одно из них, чтобы иметь полную однозначность среди имен ваших функций. И попробуй еще раз.

Другие вопросы по тегам