<div class="quiz__wrap">
<div class="quiz">
<h2 class="quiz__type"></h2>
<h3 class="quiz__question">
<span class="quiz__number"></span>
<span class="quiz__ask"></span>
</h3>
<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">
<input class="select" type="radio" id="select1" name="select" value="1">
<span class="choice"></span>
</label>
<label for="select2">
<input class="select" type="radio" id="select2" name="select" value="2">
<span class="choice"></span>
</label>
<label for="select3">
<input class="select" type="radio" id="select3" name="select" value="3">
<span class="choice"></span>
</label>
<label for="select4">
<input class="select" type="radio" id="select4" name="select" value="4">
<span class="choice"></span>
</label>
</div>
<button class="quiz__confirm">정답 확인하기</button>
<div class="quiz__result"></div>
<div class="quiz__ex"></div>
</div>
</div>
<!-- //quiz01 -->
</div>
.quiz__wrap {
display: flex;
align-items: center;
justify-content: center;
flex-wrap: wrap;
}
.quiz {
max-width: 500px;
width: 100%;
background: #fff;
border: 8px ridge #CACACA;
margin: 10px;
}
.quiz__type {
background: #CACACA;
text-align: center;
font-size: 14px;
color: #3B3B3B;
border: 3px ridge #CACACA;
padding: 3px 0;
position: relative;
}
.quiz__type::after {
content: '';
position: absolute;
right: 1px;
top: 1px;
width: 5px;
height: 5px;
border: 10px ridge #940728;
}
.quiz__type::before {
content: '';
position: absolute;
left: 1px;
top: 1px;
width: 5px;
height: 5px;
border: 10px ridge #940728;
}
.quiz__question {
border-top: 6px ridge #cacaca;
border-bottom: 6px ridge #cacaca;
padding: 13px 30px;
font-size: 24px;
line-height: 1.4;
}
.quiz__number {
font-family: 'Cafe24Dangdanghae';
color: #940728;
}
.quiz__ask {
font-family: 'Cafe24Dangdanghae';
}
.quiz__view {
background: #f5f5f5;
position: relative;
}
.quiz__view .true {
position: absolute;
left: 70%;
top: 100px;
width: 120px;
height: 120px;
border-radius: 50%;
z-index: 100;
line-height: 120px;
text-align: center;
color: #fff;
background: #F5534F;
opacity: 0;
}
.quiz__view .false {
position: absolute;
right: 70%;
top: 100px;
width: 120px;
height: 120px;
border-radius: 50%;
z-index: 100;
line-height: 120px;
text-align: center;
background: #fff;
color: #F5534F;
opacity: 0;
}
.quiz__view.like .true {
opacity: 1;
animation: wobble 0.6s;
}
.quiz__view.dislike .false {
opacity: 1;
animation: wobble 0.6s;
}
@keyframes wobble {
0% {transform: translateZ(0)}
15% {transform: translate3d(-25%, 0, 0) rotate(-5deg)}
30% {transform: translate3d(20%, 0, 0) rotate(3deg)}
45% {transform: translate3d(-15%, 0, 0) rotate(-3deg)}
60% {transform: translate3d(10%, 0, 0) rotate(2deg)}
75% {transform: translate3d(-5%, 0, 0) rotate(-1deg)}
100% {transform: translateZ(0)}
}
.quiz__answer {
background: #f5f5f5;
border-top: 6px ridge #cacaca;
padding: 10px;
}
.quiz__confirm {
border: 6px ridge #cacaca;
width: 100%;
font-size: 22px;
padding: 13px 20px;
background: #d6d6d6;
font-family: 'Cafe24Dangdanghae';
text-shadow: 1px 1px 1px #fff;
cursor: pointer;
}
.quiz__confirm:hover {
background: #b3b3b3;
}
.quiz__result {
text-align: center;
border: 6px ridge #cacaca;
width: 100%;
font-size: 22px;
padding: 13px 20px;
background: #fff;
font-family: 'Cafe24Dangdanghae';
text-shadow: 1px 1px 1px #fff;
}
.quiz__input {
text-align: center;
width: 100%;
border: 6px ridge #cacaca;
font-size: 22px;
padding: 13px 20px;
background: #fff;
font-family: 'Cafe24Dangdanghae';
text-shadow: 1px 1px 1px #fff;
margin-bottom: 10px;
}
.quiz__selects {
margin-top: 15px;
margin-bottom: 20px;
}
.quiz__selects label {
display: flex;
}
.quiz__selects label input{
position: absolute;
left: -9999px;
}
.quiz__selects label span{
font-size: 20px;
line-height: 1.3;
padding: 10px 30px 10px 20px;
margin: 3px 0;
border-radius: 5px;
font-family: 'Cafe24Dangdanghae';
display: flex;
align-items: center;
cursor: pointer;
transition: all 0.25s;
}
.quiz__selects label span::before {
content: '';
width: 30px;
height: 30px;
border-radius: 50%;
margin-right: 15px;
background: #fff;
display: flex;
flex-shrink: 0;
box-shadow: inset 0 0 0 4px #64a30b;
transition: all 0.25s;
}
.quiz__selects label input:checked + span{
background-color: #f5ffe7;
}
.quiz__selects label input:checked + span::before {
box-shadow: inset 0 0 0 10px #64a30b;
}
const quizType = document.querySelector(".quiz__type"); //퀴즈 종류들
const quizNumber = document.querySelector(".quiz__number"); //퀴즈 번호
const quizAsk = document.querySelector(".quiz__ask"); //퀴즈 질문
const quizConfirm = document.querySelector(".quiz__confirm"); //퀴즈 확인 버튼
const quizResult = document.querySelector(".quiz__result"); //퀴즈 정답
const quizView = document.querySelector(".quiz__view") //강아지
const quizSelects = document.querySelector(".quiz__selects") //객관식 보기
const quizChoice = document.querySelectorAll(".choice") //객관식 보기
const quizSelect = document.querySelectorAll(".select") //객관식 보기
//문제정보
const quizInfo = [
{
answerType : "javasript",
answerNum : 1,
answerAsk : "객체 기반의 스크립트 프로그래밍 언어는 무엇일까요?",
answerChoice : ["html", "css", "javasript", "react"],
answerResult : "3",
answerEx : "정답은 javasript 입니다."
}
];
//문제출력
function updatQuiz(){
//타입, 문제, 정답, 보기
quizType.textContent = quizInfo[0].answerType;
quizNumber.textContent = quizInfo[0].answerNum;
quizAsk.textContent = quizInfo[0].answerAsk;
quizResult.textContent = quizInfo[0].answerEx;
for(let i=0; i<4; i++){
quizChoice[i].textContent = quizInfo[0].answerChoice[i];
}
//설명 감추기
quizResult.style.display = "none";
}
updatQuiz();
//정답 확인
function answerQuiz(){
//사용자가 클릭한 인풋 --> 체크드 : 사용자가 선택한 정답 == 객체 안에 정답
for(let i=0; i<quizSelect.length; i++){
if(quizSelect[i].checked == true){
quizConfirm.style.display = "none";
if(quizSelect[i].value == quizInfo[0].answerResult){
//정답
quizView.classList.add("like");
} else {
//오답
quizView.classList.add("dislike");
quizResult.style.display = "block";
}
}
}
}
quizConfirm.addEventListener("click", answerQuiz)