Quiz 객관식(한문제) 유형

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
kkb7528@naver.com
소스 보기
Javascript
Html
Css
//문제정보
const quizInfo = [
{
    answerType : "웹디자인기능사 2011년 02회",
    answerNum : "1",
    answerAsk : "검은 종이 위에 노랑과 파랑을 나열하고 일정한 거리에서 보면 노랑이 파랑보다 가깝게 보인다. 이때의 노랑색을 무엇이라 하는가?",
    answerChoice : {
        1: "후퇴색",
        2: "팽창색",
        3: "진출색",
        4: "수축색"
    },
    answerResult : "3",
    answerEx : "후퇴색(멀어져 보이는 색), 팽창색(확대되어 보이는 색), 진출색(가깝게 보이는 색), 수축색(줄어들게 보이는 색)"
},
{
    answerType : "웹디자인기능사 2011년 02회",
    answerNum : "2",
    answerAsk : "다음 중 시각 디자인에 속하지 않는 것은?",
    answerChoice : {
        1: "텍스트타일 디자인",
        2: "패키지 디자인",
        3: "POP 디자인",
        4: "타이포그래피"
    },
    answerResult : "1",
    answerEx : "텍스트타일 디자인은 제품디자인에 속합니다."
},
...
{
    answerType : "웹디자인기능사 2011년 02회",
    answerNum : "60",
    answerAsk : "PNG 파일 포맷의 설명으로 올바른 것은?",
    answerChoice : {
        1: "Interlaced 옵션이 가능하다.",
        2: "이미지 정보를 손실 압축한다.",
        3: "인터넷 익스플로러 6.0에서는 사용할 수 없는 이미지 파일 포맷이다.",
        4: "하나의 파일로 애니메이션 효과를 만들 수 있다."
    },
    answerResult : "1",
    answerEx : "PNG파일은 JPG파일과 GIF 파일의 장점을 취하야 만든 형식으로 무손실압축 방식을 이용하며, 투명한 배경색은 표현할 수 있으나 움직이는 애니메이션 효과는 만들수 없습니다."
},


];

const quizWrap = document.querySelector(".quiz__wrap");
let quizScore = 0;

//문제 출력
const updateQuiz = () => {
const exam = [];

quizInfo.forEach((question, number) => {
    exam.push(`<div class="quiz">
    <span class="quiz__type">${question.answerType}</span>
    <h2 class="quiz__question">
        <span class="number">${question.answerNum}</span>
        <div class="ask">${question.answerAsk}</div>
    </h2>
    <div class="quiz__view">
        <div class="true">정답입니다 !</div>
        <div class="false">틀렸습니다 !</div>
        <div class="dog">
            <div class="head">
                <div class="ears"></div>
                <div class="face"></div>
                <div class="eyes">
                    <div class="teardrop"></div>
                </div>
                <div class="nose"></div>
                <div class="mouth">
                    <div class="tongue"></div>
                </div>
                <div class="chin"></div>
            </div>
            <div class="body">
                <div class="tail"></div>
                <div class="legs"></div>
            </div>
        </div>
    </div>
    <div class="quiz__answer">
        <div class="quiz__selects">
            <label for="select1${number}">
                <input type="radio" id="select1${number}" class="select" name="select${number}" value="1">
                <span class="choice">${question.answerChoice[1]}</span>
            </label>
            <label for="select2${number}">
                <input type="radio" id="select2${number}" class="select" name="select${number}" value="2">
                <span class="choice">${question.answerChoice[2]}</span>
            </label>
            <label for="select3${number}">
                <input type="radio" id="select3${number}" class="select" name="select${number}" value="3">
                <span class="choice">${question.answerChoice[3]}</span>
            </label>
            <label for="select4${number}">
                <input type="radio" id="select4${number}" class="select" name="select${number}" value="4">
                <span class="choice">${question.answerChoice[4]}</span>
            </label>
            </div>
    </div>
</div>`);
});

exam.push(`
        <div class="quiz__confirm">
            <button class="check">정답 확인하기</button>
            <div class="ex"></div>
        </div>
    `);

quizWrap.innerHTML = exam.join('');
}
updateQuiz();



//정답 확인
const answerQuiz = () => {
const quizSelects = document.querySelectorAll(".quiz__selects");    //객관식 보기
const quizConfirm = document.querySelector(".quiz__confirm .check");    //정답 보기

//사용자 체크 보기 == 문제 정답
quizInfo.forEach((question, number) => {
    const userSelector = `input[name=select${number}]:checked`; //사용자가 체크한 보기
    const quizSelectsWrap = quizSelects[number];  //사용자가 푼 문제 번호 60개 중에 몇번
    const userAnswer = (quizSelectsWrap.querySelector(userSelector) || {}).value;
    const quizView = document.querySelectorAll(".quiz__view");  //강아지

    if(userAnswer == question.answerResult){
        console.log("정답")
        quizView[number].classList.add("like");
        quizScore++;
    } else {
        console.log("오답")
        quizView[number].classList.add("dislike");
        const divBox = document.createElement("div");
        quizSelectsWrap.appendChild(divBox).innerHTML = `<p class="result">${question.answerEx}</p>`;
    }
    


});

quizConfirm.textContent = `${quizScore < 36 ? "총 " + quizInfo.length + "문제 중에 " + quizScore + "문제를 맞추었습니다. 결과는 탈락입니다!" :  "총 " + quizInfo.length + "문제 중에" + quizScore + " 문제를 맞추었습니다. 결과는 합격입니다!"}`;



//전체 문제수
// console.log(quizInfo.length)

//내가 맞힌 수
// console.log(quizScore)
}

//정답 클릭
document.querySelector(".quiz__confirm .check").addEventListener("click", answerQuiz);
<div class="quiz__wrap"></div>
/* quiz__wrap */
.quiz__wrap {
display: flex;
align-items: flex-start;
justify-content: center;
margin-top: 50px;
margin-bottom: 150px;
flex-wrap: wrap;
}

.quiz {
max-width: 500px;
width: 100%;
background-color: #fff;
border: 8px ridge #cacaca;
margin: 10px;
}

.quiz__type {
background-color: #cacaca;
text-align: center;
display: block;
font-size: 16px;
border: 3px ridge #cacaca;
color: #3b3b3b;
font-family: "DungGeunMo";
padding: 4px;
}

.quiz__question {
border-top: 6px ridge #cacaca;
border-bottom: 6px ridge #cacaca;
padding: 20px;
font-family: "NanumBarunpen";
line-height: 1.3;
}

.quiz__question .number {
padding: 0 10px;
border-radius: 10px;
background-color: #f69a06a0;
color: #fff;
font-size: 20px;
}

.quiz__question .ask {
display: inline;
}

.quiz__answer {
border-top: 6px ridge #cacaca;
padding: 10px;
background-color: #f5f5f5;
}

.quiz__answer .input {
width: 100%;
border: 6px ridge #cacaca;
font-size: 22px;
padding: 13px 20px;
background-color: #fff;
font-family: "NanumBarunpen";
margin-bottom: 10px;
}

.quiz__answer .confirm {
border: 6px ridge #cacaca;
width: 100%;
font-size: 22px;
padding: 13px 20px;
background-color: #d6d6d6;
font-family: "NanumBarunpen";
cursor: pointer;
}

.quiz__answer .result {
border: 6px ridge #cacaca;
width: 100%;
font-size: 22px;
line-height: 1.3;
padding: 13px 20px;
box-sizing: border-box;
text-align: center;
font-family: "NanumBarunpen";
}

.quiz__view {
background-color: #f5f5f5;
font-family: "NanumBarunpen";
position: relative;
overflow: hidden;
}

.quiz__view .true {
width: 120px;
height: 120px;
line-height: 120px;
background-color: #f69a06a0;
border-radius: 50%;
text-align: center;
position: absolute;
left: 70%;
top: 100px;
opacity: 0;
}

.quiz__view .false {
width: 120px;
height: 120px;
line-height: 120px;
background-color: rgba(105, 105, 105, 0.152);
border-radius: 50%;
text-align: center;
position: absolute;
right: 70%;
top: 100px;
opacity: 0;
}

.quiz__view.like .true {
opacity: 1;
animation: wobble 0.6s;
}

.quiz__view.dislike .false {
opacity: 1;
animation: wobble 0.6s;
}

.quiz__selects {
margin: 5px 0;
}
.quiz__selects label {
display: flex;
}
.quiz__selects label input {
position: absolute;
left: -9999px;
}
.quiz__selects label span {
font-size: 20px;
line-height: 1.3;
font-family: "NanumBarunpen";
padding: 10px 10px 10px 10px;
display: flex;
align-items: center;
width: 100%;
border-radius: 10px;
cursor: pointer;
}
.quiz__selects label span::before {
content: '';
width: 30px;
height: 30px;
border-radius: 50%;
background: #fff;
margin-right: 15px;
display: flex;
flex-shrink: 0;
box-shadow: inset 0px 0px 0px 4px #f69a06a0;
transition: all 0.25s;
}
/* 친구일때는 + */
.quiz__selects label input:checked + span {
background-color: #f69a0621;
}
.quiz__selects label input:checked + span::before {
box-shadow: inset 0px 0px 0px 8px #f69a06a0;
}
.quiz__confirm {
width: 100%;
text-align: center;
}
.quiz__confirm .check {
border: 6px ridge #cacaca;
font-size: 22px;
line-height: 1.3;
padding: 13px 60px;
box-sizing: border-box;
text-align: center;
font-family: "NanumBarunpen";
cursor: pointer;
margin: 40px 0;
transition: background 0.3s;
}
.quiz__confirm .check:hover {
background: #f69a0668;
}

@keyframes wobble {

/* 0% 시작 ~ 100% 끝 */
0% {
    transform: translateX(0) rotate(0deg);
}

15% {
    transform: translateX(-25%) rotate(-5deg);
}

30% {
    transform: translateX(20%) rotate(3deg);
}

45% {
    transform: translateX(-15%) rotate(-3deg);
}

60% {
    transform: translateX(10%) rotate(2deg);
}

75% {
    transform: translateX(-5%) rotate(-1deg);
}

100% {
    transform: translateX(0) rotate(0deg);
}
}