Quiz 정답 확인하기 유형

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

kkb7528@naver.com
소스 보기
Javascript
Html
Css
//선택자
const quizType = document.querySelector(".quiz__type");      //퀴즈 종류
const quizNumber = document.querySelector(".quiz__question .number");      //퀴즈 번호
const quizAsk = document.querySelector(".quiz__question .ask");      //퀴즈 질문
const quizConfirm = document.querySelector(".quiz__answer .confirm");       //정답 확인 버튼
const quizResult = document.querySelector(".quiz__answer .result");      //퀴즈 정답
const quizDog = document.querySelector(".quiz__view .dog");     //강아지

//문제 정보 (데이터 저장)
const answerType = "웹디자인기능사";
const answerNum = 1;
const answerAsk = "인접하는 두 색의 경계 부분에 색상, 명도, 채도의 대비가 더욱 강하게 일어나는 현상을 무엇이라고 하는가?";
const answerResult = "연변대비";

//문제 출력 (데이터 출력)
quizType.innerText = answerType;        //innerText 자바스크립트에서 만들어 놓은 객체
quizNumber.innerText = answerNum;
quizAsk.innerText = answerAsk;
quizResult.innerText = answerResult;

//정답 숨기기
quizResult.style.display = "none";

//정답 확인
//정답 버튼을 클릭하면 확인 버튼은 안보이고 숨겨진 버튼이 보이도록
//정답을 확인하면 강아지가 웃고 있어야 함, class like 추가
quizConfirm.addEventListener("click", function(){        //버튼을 클릭하면 함수를실행해라
quizConfirm.style.display = "none";
quizResult.style.display = "block";
});
<div class="quiz__wrap">
<div class="quiz">
    <span class="quiz__type"></span>
    <h2 class="quiz__question">
        <span class="number"></span>
        <div class="ask"></div>
    </h2>
    <div class="quiz__view">
        <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">
        <button class="confirm">정답 확인하기</button>
        <div class="result"></div>
    </div>
</div>
</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);
}
}