forked from GalsenDev221/hacktoberfest.quiz.2023
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
108 lines (96 loc) · 2.92 KB
/
script.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
const questions = [
{
question: "Quelle est la période du Hacktoberfest durant l'annee ?",
options: ["Octobre", "Décembre", "Mai", "Août"],
correctAnswer: 0,
},
{
question: "Où pouvez-vous contribuer pour participer au Hacktoberfest ?",
options: ["AWS", "Facebook", "GitHub", "DigitaOcean"],
correctAnswer: 2,
},
{
question:
"Combien de contributions sont nécessaires pour valider le Hacktoberfest ?",
options: ["10", "2", "6", "4"],
correctAnswer: 3,
},
{
question: "Quelles sont les deux langues officielles du Canada ? (choix multiple)",
options: ["Français", "Anglais", "Espagnol", "Allemand"],
correctAnswer: [0, 1],
},
{
question: "Est-ce ce que GitLab participe au Hacktoberfest ?",
options: ["Oui", "Non"],
correctAnswer: 0,
},
{
question: "Quelle societe a cree le hacktoberfest ?",
options: ["DigitalOcean", "Microsoft", "galsenDev", "xarala"],
correctAnswer: 0,
},
{
question: "Combien de temps dure l'evenement Hacktoberfest ?",
options: ["1 ans", "1 mois", "1 week-end"],
correctAnswer: 1,
},
];
let currentQuestion = 0;
let score = 0;
let correctAnswers = 0
let numberOfClick = 0
const questionElement = document.getElementById("question");
const optionsElement = document.getElementById("options");
const scoreElement = document.getElementById("score");
function loadQuestion() {
const question = questions[currentQuestion];
questionElement.textContent = question.question;
optionsElement.innerHTML = "";
question.options.forEach((option, index) => {
const li = document.createElement("li");
li.textContent = option;
li.addEventListener("click", function () { return checkAnswer(index, this) });
optionsElement.appendChild(li);
});
}
function checkAnswer(selectedIndex, currentList) {
const question = questions[currentQuestion];
if (Array.isArray(question.correctAnswer)) {
numberOfClick++
currentList.classList.add("active");
if (question.correctAnswer.includes(selectedIndex)) {
correctAnswers++
}
if (numberOfClick === question.correctAnswer.length) {
if (correctAnswers === question.correctAnswer.length) {
score++
scoreElement.innerText = score
}
numberOfClick = 0
correctAnswers = 0
currentQuestion++;
if (currentQuestion < questions.length) {
loadQuestion();
} else {
questionElement.textContent = "Quiz terminé ! Votre score :";
optionsElement.innerHTML = "";
scoreElement.textContent = score;
}
}
return
}
if (selectedIndex === question.correctAnswer) {
score++;
scoreElement.innerText = score
}
currentQuestion++;
if (currentQuestion < questions.length) {
loadQuestion();
} else {
questionElement.textContent = "Quiz terminé ! Votre score :";
optionsElement.innerHTML = "";
scoreElement.textContent = score;
}
}
loadQuestion();