티스토리 뷰

Script Sample/Quiz Effect

quizEffect05

GYChoi 2022. 2. 22. 12:31

https://garenchoi.github.io/webs_class/javascript/effect/quizEffect05.html

const quizWrap = document.querySelector(".quiz__wrap");	//quizWrap에 클래스 quiz__wrap저장

//문제 정보
const quizInfo = [			//quizInfo에 문제 정보 저장
    {
        answerType : "javascript",
        answerNum : 1,
        answerAsk : "객체 기반의 스크립트 프로그래밍 언어는 무엇입니까?",
        answerChoice : {
            1: "html",
            2: "css",
            3: "javascript",
            4: "react"  
        },
        answerResult : "3",
        answerEx : "객체 기반의 스크립트 프로그래밍 언어는 javascript입니다."
    },
    {
        answerType : "HTML",
        answerNum : 2,
        answerAsk : "컨텐츠의 구조를 정의하는 마크업 언어는 무엇일까요?",
        answerChoice : {
            1: "html",
            2: "css",
            3: "javascript",
            4: "react"  
        },
        answerResult : "1",
        answerEx : "컨텐츠의 구조를 정의하는 마크업 언어는 HTML입니다."
    },
    {
        answerType : "CSS",
        answerNum : 3,
        answerAsk : "웹페이지를 꾸미기 위해 사용하는 언어는 무엇입니까?",
        answerChoice : {
            1: "html",
            2: "css",
            3: "javascript",
            4: "react"  
        },
        answerResult : "2",
        answerEx : "웹페이지를 꾸미기 위해 사용하는 언어는 css입니다."
    }
];

//문제 출력
function updataQuiz(){			//함수 updataQuiz 선언
    const html = [];			//변수 html 배열로 선언

    quizInfo.forEach((question, number) => {			//quizInfo(문제 정보)의 element값들을 question에 index값들을 number에 저장
        html.push(`				//변수 html에 push로 추가
            <div class="quiz">
                <h2 class="quiz__type">${question.answerType}</h2>		//${question.answerType} : question(quizInfo의 element값)의 answerType
                <h3 class="quiz__question">
                    <span class="quiz__number">${question.answerNum}</span>		//${question.answerNum} : question(quizInfo의 element값)의 answerNum
                    <span class="quiz__ask">${question.answerAsk}</span>		//${question.answerAsk} : question(quizInfo의 element값)의 answerAsk
                </h3>
                <div class="quiz__view">
                    <div class="true">정답입니다.</div>
                    <div class="false">틀렸습니다.</div>
                    <div class="dog"></div>
                </div>
                <div class="quiz__answer">
                    <div class="quiz__selects">
                        <label for="select1${number}">
                            <input class="select" type="radio" id="select1${number}" name="select${number}" value="1">
                            <span class="choice">${question.answerChoice[1]}</span>
                        </label>
                        <label for="select2${number}">
                            <input class="select" type="radio" id="select2${number}" name="select${number}" value="2">
                            <span class="choice">${question.answerChoice[2]}</span>
                        </label>
                        <label for="select3${number}">
                            <input class="select" type="radio" id="select3${number}" name="select${number}" value="3">
                            <span class="choice">${question.answerChoice[3]}</span>
                        </label>
                        <label for="select4${number}">
                            <input class="select" type="radio" id="select4${number}" name="select${number}" value="4">
                            <span class="choice">${question.answerChoice[4]}</span>
                        </label>
                    </div>
                </div>
            </div>
        `)
    });

    html.push(`		//변수 html마지막에 추가
        <div class="quiz__btn">
            <button class="quiz__confirm">정답 확인하기</button>
            <div class="quiz__result"></div>
        </div>
    `);
    quizWrap.innerHTML = html.join("");		//quizWrap에 html.join("") (.join("") : 배열 사이의 ,제거)출력
    
}

updataQuiz();		//함수 updataQuiz 실행

function answerQuiz(){		//함수 answerQuiz 선언
    const quizSelects = document.querySelectorAll(".quiz__selects");    //quizSelects에 클래스 quiz__selects(보기 선택 박스)저장
    const quizView = document.querySelectorAll(".quiz__view");  		//quizView에 클래스 quiz__view(퀴즈 화면)저장
    const quizResult = document.querySelector(".quiz__result"); 		//quizResult에 클래스 quiz__result(정답 결과)저장

    let scoreCurrent = 0;   	//변수 scoreCurrent 0으로 선언
    
    quizInfo.forEach((question, number) => {			//quizInfo의 element값들을 question에 index값들을 number에 저장
        const quizSelectsWrap = quizSelects[number];                //quizSelectsWrap에 quizSelects의 number번째 값들을 저장
        const userSeletor = `input[name=select${number}]:checked`   //userSeletor에 input의 name값이 selectnumber(number=index값)인 것들 중 체크된 것(사용자가 선택한 정답)을 저장
        const userAnswer = (quizSelectsWrap.querySelector(userSeletor) || {}).value;    //userAnswer에 quizSelectsWrap중 userSeletor의 값 혹은 빈 객체의 값을 저장
        
        if(userAnswer == question.answerResult){		//userAnswer이 question의 question와 같을 때
            quizView[number].classList.add("like");		//quizView의 number번째에 클래스 like 추가
            scoreCurrent++								//scoreCurrent 1씩 증가
        } else{				//userAnswer이 question의 question와 같지 않을 때
            quizView[number].classList.add("dislike");		//quizView의 number번째에 클래스 dislike 추가
            const div = document.createElement("div");		//변수 div에 div태그 만들어서 저장
            quizSelectsWrap.appendChild(div).innerHTML = `<p class="quiz__ex">${question.answerEx}</p>`;
            //quizSelectsWrap에 자식요소로 변수 div추가하고 div에 <p class="quiz__ex">${question.answerEx}</p> 출력 (question.answerEx : 문제 해설)
        }
    });
    quizResult.innerHTML = `${quizInfo.length} 문제 중 ${scoreCurrent} 문제를 맞추었습니다.`		//quizResult에 ${quizInfo.length} 문제 중 ${scoreCurrent} 문제를 맞추었습니다. 출력(결과 보여주기)
}

document.querySelector(".quiz__confirm").addEventListener("click", answerQuiz);		//클래스 quiz__confirm(정답 확인 버튼)를 클릭 했을 때 함수 answerQuiz 실행

'Script Sample > Quiz Effect' 카테고리의 다른 글

quizEffect04  (0) 2022.02.22
quizEffect03  (0) 2022.02.22
quizEffect02  (0) 2022.02.21
quizEffect01  (0) 2022.02.21
댓글
© 2018 webstoryboy