Ciao lettori, oggi in questo blog imparerai come creare un’applicazione per quiz con timer utilizzando HTML CSS e JavaScript. In precedenza ho condiviso un blog su come creare un sito Web di portfolio personale reattivo e ora è il momento di creare un’app Web Quiz utilizzando JavaScript.
In questo programma [App Quiz con Timer], ci sono tre livelli o riquadri, e questi riquadri mostrati uno ad uno su un particolare pulsante cliccato. All’inizio, sulla pagina web, viene mostrato un pulsante etichettato come “Avvia quiz” e quando hai fatto clic su quel pulsante, viene visualizzata la finestra delle informazioni con un’animazione popup.
In questa infobox, ci sono alcune regole del quiz e due pulsanti etichettati come “Esci” e “Continua”. Quando hai fatto clic sul pulsante Esci, la casella delle informazioni sarà nascosta, ma quando hai fatto clic sul pulsante Continua, viene visualizzata la casella Quiz.
Nella casella del quiz, c’è un’intestazione con un titolo sul lato sinistro e una casella del timer sul lato destro. Questo timer inizia a diminuire da 15 a 0 secondi e viene anche mostrato un indicatore della sequenza temporale che scorre da sinistra a destra in base al timer. Se l’utente seleziona un’opzione compresa tra 15 e 0 secondi, il timer verrà interrotto e tutte le opzioni disponibili verranno disabilitate.
Se l’opzione selezionata dall’utente è corretta, il colore dell’opzione selezionata, il colore di sfondo cambia in verde e viene visualizzata anche l’icona di spunta per informare l’utente che la risposta selezionata è corretta. Se l’utente seleziona un’opzione errata, il colore dell’opzione selezionata, il colore di sfondo cambia in rosso e viene visualizzata l’icona a forma di croce per informare l’utente che l’opzione selezionata non è corretta e l’opzione corretta verrà automaticamente selezionata.
Se l’utente non seleziona un’opzione compresa tra 15 e 0 secondi, il timer verrà interrotto quando arriva a 0 e l’opzione corretta di quella domanda verrà selezionata automaticamente. Dopodiché, c’è il pulsante successivo per mostrare la domanda successiva e ci sono un totale di cinque domande su questo quiz.
Alla fine, apparirà la casella del risultato e mostrerà il punteggio dell’utente e due pulsanti [Ripeti quiz, Esci quiz], se l’utente ha cliccato sul pulsante replay quiz, il quiz ricomincerà con la domanda numero 1 e il punteggio dell’utente sarà 0 ma se l’utente ha fatto clic sul pulsante esci dal quiz, la finestra corrente verrà ricaricata e il quiz ricomincerà dall’inizio.
Tutorial video per creare un’app per quiz con timer
Nel video, hai visto l’anteprima effettiva dell’applicazione Quiz con Timer e spero che tu abbia compreso i codici alla base della creazione di questo layout Quiz Box. In questo video ho scritto solo i codici HTML e CSS e nella seconda parte di questo video ho completato i codici JavaScript di questo programma. Se non hai visto la parte 2 di questo video, clicca qui per guardarlo ora.
Puoi usare questo quiz e puoi anche aggiungere più domande a questo quiz. Nei codici sorgente, ho scritto molti commenti su come aggiungere più domande e spiegato ogni riga JavaScript di questo quiz. Se sei un principiante, potresti avere difficoltà a capire i codici JavaScript ma puoi facilmente capire i codici HTML e CSS e ho cercato di spiegare tutte le righe JavaScript con commenti, spero che tu capisca.
Per creare questo programma (Applicazione Quiz con Timer). Innanzitutto, devi creare quattro file, uno HTML, CSS e gli altri due sono JavaScript. Dopo aver creato questi file, incolla i seguenti codici nel tuo file.
Innanzitutto, crea un file HTML con il nome di index.html e incolla i codici forniti nel tuo file HTML. Ricorda, devi creare un file con estensione .html.
<!DOCTYPE html> <!-- Created By CodingNepal - www.codingnepalweb.com --> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Awesome Quiz App | CodingNepal</title> <link rel="stylesheet" href="style.css"> <!-- FontAweome CDN Link for Icons --> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css"/> </head> <body> <!-- start Quiz button --> <div class="start_btn"><button>Start Quiz</button></div> <!-- Info Box --> <div class="info_box"> <div class="info-title"><span>Some Rules of this Quiz</span></div> <div class="info-list"> <div class="info">1. You will have only <span>15 seconds</span> per each question.</div> <div class="info">2. Once you select your answer, it can't be undone.</div> <div class="info">3. You can't select any option once time goes off.</div> <div class="info">4. You can't exit from the Quiz while you're playing.</div> <div class="info">5. You'll get points on the basis of your correct answers.</div> </div> <div class="buttons"> <button class="quit">Exit Quiz</button> <button class="restart">Continue</button> </div> </div> <!-- Quiz Box --> <div class="quiz_box"> <header> <div class="title">Awesome Quiz Application</div> <div class="timer"> <div class="time_left_txt">Time Left</div> <div class="timer_sec">15</div> </div> <div class="time_line"></div> </header> <section> <div class="que_text"> <!-- Here I've inserted question from JavaScript --> </div> <div class="option_list"> <!-- Here I've inserted options from JavaScript --> </div> </section> <!-- footer of Quiz Box --> <footer> <div class="total_que"> <!-- Here I've inserted Question Count Number from JavaScript --> </div> <button class="next_btn">Next Que</button> </footer> </div> <!-- Result Box --> <div class="result_box"> <div class="icon"> <i class="fas fa-crown"></i> </div> <div class="complete_text">You've completed the Quiz!</div> <div class="score_text"> <!-- Here I've inserted Score Result from JavaScript --> </div> <div class="buttons"> <button class="restart">Replay Quiz</button> <button class="quit">Quit Quiz</button> </div> </div> <!-- Inside this JavaScript file I've inserted Questions and Options only --> <img src="" data-wp-preserve="%3Cscript%20src%3D%22js%2Fquestions.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" /> <!-- Inside this JavaScript file I've coded all Quiz Codes --> <img src="" data-wp-preserve="%3Cscript%20src%3D%22js%2Fscript.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" /> </body> </html>
In secondo luogo, crea un file CSS con il nome di style.css e incolla i codici forniti nel tuo file CSS. Ricorda, devi creare un file con estensione .css.
/* importing google fonts */ @import url('https://fonts.googleapis.com/css2?family=Poppins:wght@200;300;400;500;600;700&display=swap'); *{ margin: 0; padding: 0; box-sizing: border-box; font-family: 'Poppins', sans-serif; } body{ background: #007bff; } ::selection{ color: #fff; background: #007bff; } .start_btn, .info_box, .quiz_box, .result_box{ position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19); } .info_box.activeInfo, .quiz_box.activeQuiz, .result_box.activeResult{ opacity: 1; z-index: 5; pointer-events: auto; transform: translate(-50%, -50%) scale(1); } .start_btn button{ font-size: 25px; font-weight: 500; color: #007bff; padding: 15px 30px; outline: none; border: none; border-radius: 5px; background: #fff; cursor: pointer; } .info_box{ width: 540px; background: #fff; border-radius: 5px; transform: translate(-50%, -50%) scale(0.9); opacity: 0; pointer-events: none; transition: all 0.3s ease; } .info_box .info-title{ height: 60px; width: 100%; border-bottom: 1px solid lightgrey; display: flex; align-items: center; padding: 0 30px; border-radius: 5px 5px 0 0; font-size: 20px; font-weight: 600; } .info_box .info-list{ padding: 15px 30px; } .info_box .info-list .info{ margin: 5px 0; font-size: 17px; } .info_box .info-list .info span{ font-weight: 600; color: #007bff; } .info_box .buttons{ height: 60px; display: flex; align-items: center; justify-content: flex-end; padding: 0 30px; border-top: 1px solid lightgrey; } .info_box .buttons button{ margin: 0 5px; height: 40px; width: 100px; font-size: 16px; font-weight: 500; cursor: pointer; border: none; outline: none; border-radius: 5px; border: 1px solid #007bff; transition: all 0.3s ease; } .quiz_box{ width: 550px; background: #fff; border-radius: 5px; transform: translate(-50%, -50%) scale(0.9); opacity: 0; pointer-events: none; transition: all 0.3s ease; } .quiz_box header{ position: relative; z-index: 2; height: 70px; padding: 0 30px; background: #fff; border-radius: 5px 5px 0 0; display: flex; align-items: center; justify-content: space-between; box-shadow: 0px 3px 5px 1px rgba(0,0,0,0.1); } .quiz_box header .title{ font-size: 20px; font-weight: 600; } .quiz_box header .timer{ color: #004085; background: #cce5ff; border: 1px solid #b8daff; height: 45px; padding: 0 8px; border-radius: 5px; display: flex; align-items: center; justify-content: space-between; width: 145px; } .quiz_box header .timer .time_left_txt{ font-weight: 400; font-size: 17px; user-select: none; } .quiz_box header .timer .timer_sec{ font-size: 18px; font-weight: 500; height: 30px; width: 45px; color: #fff; border-radius: 5px; line-height: 30px; text-align: center; background: #343a40; border: 1px solid #343a40; user-select: none; } .quiz_box header .time_line{ position: absolute; bottom: 0px; left: 0px; height: 3px; background: #007bff; } section{ padding: 25px 30px 20px 30px; background: #fff; } section .que_text{ font-size: 25px; font-weight: 600; } section .option_list{ padding: 20px 0px; display: block; } section .option_list .option{ background: aliceblue; border: 1px solid #84c5fe; border-radius: 5px; padding: 8px 15px; font-size: 17px; margin-bottom: 15px; cursor: pointer; transition: all 0.3s ease; display: flex; align-items: center; justify-content: space-between; } section .option_list .option:last-child{ margin-bottom: 0px; } section .option_list .option:hover{ color: #004085; background: #cce5ff; border: 1px solid #b8daff; } section .option_list .option.correct{ color: #155724; background: #d4edda; border: 1px solid #c3e6cb; } section .option_list .option.incorrect{ color: #721c24; background: #f8d7da; border: 1px solid #f5c6cb; } section .option_list .option.disabled{ pointer-events: none; } section .option_list .option .icon{ height: 26px; width: 26px; border: 2px solid transparent; border-radius: 50%; text-align: center; font-size: 13px; pointer-events: none; transition: all 0.3s ease; line-height: 24px; } .option_list .option .icon.tick{ color: #23903c; border-color: #23903c; background: #d4edda; } .option_list .option .icon.cross{ color: #a42834; background: #f8d7da; border-color: #a42834; } footer{ height: 60px; padding: 0 30px; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid lightgrey; } footer .total_que span{ display: flex; user-select: none; } footer .total_que span p{ font-weight: 500; padding: 0 5px; } footer .total_que span p:first-child{ padding-left: 0px; } footer button{ height: 40px; padding: 0 13px; font-size: 18px; font-weight: 400; cursor: pointer; border: none; outline: none; color: #fff; border-radius: 5px; background: #007bff; border: 1px solid #007bff; line-height: 10px; opacity: 0; pointer-events: none; transform: scale(0.95); transition: all 0.3s ease; } footer button:hover{ background: #0263ca; } footer button.show{ opacity: 1; pointer-events: auto; transform: scale(1); } .result_box{ background: #fff; border-radius: 5px; display: flex; padding: 25px 30px; width: 450px; align-items: center; flex-direction: column; justify-content: center; transform: translate(-50%, -50%) scale(0.9); opacity: 0; pointer-events: none; transition: all 0.3s ease; } .result_box .icon{ font-size: 100px; color: #007bff; margin-bottom: 10px; } .result_box .complete_text{ font-size: 20px; font-weight: 500; } .result_box .score_text span{ display: flex; margin: 10px 0; font-size: 18px; font-weight: 500; } .result_box .score_text span p{ padding: 0 4px; font-weight: 600; } .result_box .buttons{ display: flex; margin: 20px 0; } .result_box .buttons button{ margin: 0 10px; height: 45px; padding: 0 20px; font-size: 18px; font-weight: 500; cursor: pointer; border: none; outline: none; border-radius: 5px; border: 1px solid #007bff; transition: all 0.3s ease; } .buttons button.restart{ color: #fff; background: #007bff; } .buttons button.restart:hover{ background: #0263ca; } .buttons button.quit{ color: #007bff; background: #fff; } .buttons button.quit:hover{ color: #fff; background: #007bff; }
Infine, crea un file JavaScript con il nome di question.js e incolla i codici forniti nel tuo file JavaScript. Ricorda, devi creare un file con estensione .js. In questo file, memorizziamo tutte le domande in un array.
// creating an array and passing the number, questions, options, and answers let questions = [ { numb: 1, question: "What does HTML stand for?", answer: "Hyper Text Markup Language", options: [ "Hyper Text Preprocessor", "Hyper Text Markup Language", "Hyper Text Multiple Language", "Hyper Tool Multi Language" ] }, { numb: 2, question: "What does CSS stand for?", answer: "Cascading Style Sheet", options: [ "Common Style Sheet", "Colorful Style Sheet", "Computer Style Sheet", "Cascading Style Sheet" ] }, { numb: 3, question: "What does PHP stand for?", answer: "Hypertext Preprocessor", options: [ "Hypertext Preprocessor", "Hypertext Programming", "Hypertext Preprogramming", "Hometext Preprocessor" ] }, { numb: 4, question: "What does SQL stand for?", answer: "Structured Query Language", options: [ "Stylish Question Language", "Stylesheet Query Language", "Statement Question Language", "Structured Query Language" ] }, { numb: 5, question: "What does XML stand for?", answer: "eXtensible Markup Language", options: [ "eXtensible Markup Language", "eXecutable Multiple Language", "eXTra Multi-Program Language", "eXamine Multiple Language" ] }, // you can uncomment the below codes and make duplicate as more as you want to add question // but remember you need to give the numb value serialize like 1,2,3,5,6,7,8,9..... // { // numb: 6, // question: "Your Question is Here", // answer: "Correct answer of the question is here", // options: [ // "Option 1", // "option 2", // "option 3", // "option 4" // ] // }, ];