[TIL] 24-10-29
모달 적용하기
오늘은 팀장님이 만든 html에 모달을 적용해서 멤버별 최애 음식점을 만들어 봤다
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link
href="https://fonts.googleapis.com/css2?family=Black+Han+Sans&family=Gowun+Dodum&family=Noto+Sans+KR:wght@100..900&display=swap"
rel="stylesheet"> <!-- 글꼴 불러오기-->
<title>CSSJBR</title>
<style>
* {
font-family: "Noto Sans KR", sans-serif;
}
.title {
font-family: "Dancing Script", serif;
margin-top: 200px;
height: 200px;
margin: 0 auto;
font-size: 60px;
text-align: center;
color: #ff3d00;
line-height: 180px;
}
.title>img {
width: 70px;
float: left;
margin-top: 60px;
margin-left: 100px;
}
.six {
margin: 30px;
}
.black {
background-color: rgb(59, 59, 59);
height: 3px;
margin: 0 auto;
margin-bottom: 70px;
margin-left: 30px;
margin-right: 30px;
}
.menu {
background-color: white;
box-shadow: 0px 0px 3px 0px black;
width: 350px;
height: 350px;
font-size: 25px;
float: left;
margin-left: 50px;
margin-top: 20px;
line-height: 70px;
}
ul {
list-style: none;
}
a {
text-decoration: none;
color: black;
}
.home {
width: 35px;
}
.labtop {
width: 30px;
}
.book {
width: 30px;
}
.ping {
width: 30px;
}
.subtitle {
margin-top: 600px;
border: 3px solid #ff3d00;
border-radius: 40px;
margin: 0 auto;
width: 500px;
height: 100px;
font-size: 40px;
text-align: center;
line-height: 15px;
}
.information {
width: 1280px;
height: 1000px;
margin-left: 450px;
margin-right: 50px;
}
.information>p {
text-align: center;
font-size: 20px;
}
.introduce {
display: flex;
}
.cssjbr {
width: 400px;
height: 500px;
margin-left: 20px;
margin-top: 50px;
}
.cssjbr>p {
text-align: center;
font-size: 15px;
}
.cssjbrbox {
border: 3px solid #ff3d00;
border-radius: 40px;
height: 400px;
text-align: center;
}
.emoji {
display: inline-block;
width: 400px;
height: 500px;
margin-left: 20px;
margin-top: 50px;
}
.emoji>p {
text-align: center;
font-size: 15px;
}
.emojibox {
border: 3px solid #ff3d00;
border-radius: 40px;
height: 400px;
text-align: center;
}
.object {
display: inline-block;
width: 400px;
height: 500px;
margin-left: 20px;
margin-top: 50px;
}
.object>p {
text-align: center;
font-size: 15px;
}
.objectbox {
border: 3px solid #ff3d00;
border-radius: 40px;
height: 400px;
text-align: center;
}
.favorite-restaurant {
width: 1280px;
margin-left: 450px;
margin-right: 50px;
display: grid;
}
.fav-res {
width: 400px;
margin-left: 20px;
margin-top: 50px;
}
.fav-res-box {
border: 3px solid #ff3d00;
border-radius: 40px;
height: 200px;
text-align: center;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
.fav-res-box > p{
margin: 0;
}
.fav-res-subtitle {
grid-column: span 3;
border: 3px solid #ff3d00;
border-radius: 40px;
margin: 0 auto;
width: 500px;
height: 100px;
font-size: 40px;
text-align: center;
line-height: 15px;
}
#modal {
display: none;
background-color: yellowgreen;
width: 600px;
height: 500px;
overflow-y: auto;
margin: auto;
padding: 0 15px 0 15px;
position: fixed;
transform: translate(125%, -98%);
border-radius: 50px;
} /* 모달창 */
#modal #modal-content {
text-align: center;
padding: 50px;
width: 100%;
} /* 모달창 내용 */
#modal #modal-close {
float:right;
font-size: 40px;
padding-right: 10px;
display: inline;
cursor: pointer;
position: absolute;
top: 5px;
right: 5px;
} /* 모달창 x 버튼 */
#modal img {
max-width: 100%;
height: auto;
max-width: 300px;
max-height: 200px;
} /* 모달창 이미지 */
#modal a {
color:aquamarine;
}
#modal a:hover {
text-decoration: underline;
}
</style>
<script>
document.addEventListener("DOMContentLoaded",() => {
const modal = document.getElementById("modal");
const modalContent = document.getElementById('modal-content')
function modalOn(content) {
modalContent.innerHTML = content;
modal.style.display = "flex";
} // 모달 켜는 함수
function modalOff() {
modal.style.display = "none";
} // 모달 종료 함수
const clickModal = document.querySelectorAll(".fav-res-box"); // fav-res-box 클래스를 가진 모든 요소 선택
clickModal.forEach(clic =>{
clic.addEventListener("click", () => {
const content = clic.getAttribute("data-content");
modalOn(content);
}) // 클릭 시 data불러오고 모달 켜는 함수 실행되도록
}) // 여러개의 요소가 있기때문에 forEach로 반복
const closeModal = document.getElementById("modal-close");
closeModal.addEventListener("click", modalOff); // 클릭 시 모달 종료 함수 실행
})
</script>
</head>
<body>
<div class="title">
<img
src="">
<!--캐치테이블 로고-->
<b class="six">CSSJBR</b>
<!--조 이름-->
</div>
<div class="black">
<!--구분선-->
</div>
<div>
<div>
<nav class="menu">
<!--사이드 네비게이터-->
<ul>
<li><img class="home" src="home.png"><a href="#" title="팀 소개"> 팀 소개</a></li>
<li><img class="labtop" src="labtop.png"><a href="#" title="멤버 소개"> 멤버 소개</a></li>
<li><img class="book" src="book.png"><a href="#" title="방명록"> 방명록</a></li>
<li><img class="ping" src="ping.png"><a href="#" title="멤버들이 추천하는 맛집"> 멤버들이 추천하는 맛집</a></li>
</ul>
</nav>
</div>
<div class="favorite-restaurant"><!--정보 들어갈 공간-->
<div class="fav-res-subtitle"><!--네비게이터 항목-->
<p>멤버들이 추천하는 맛집</p>
</div>
<div class="fav-res"><!--박스 1-->
<div class="fav-res-box">
<p>맛집 1</p>
</div>
</div>
<div class="fav-res"><!--박스 2-->
<div class="fav-res-box">
<p>맛집 2</p>
</div>
</div>
<div class="fav-res"><!--박스 3-->
<div class="fav-res-box">
<p>맛집 3</p>
</div>
</div>
<div class="fav-res"><!--박스 4-->
<div class="fav-res-box" data-content="<p>김지웅의 OO동 맛집!</p><p>OO동 수제버거</p><img src='https://cdn.ypsori.com/news/photo/201901/14732_14780_325.jpg'><br><a href = 'https://example.com' target = '_black' > 식당 지도 링크</a><p>⭐⭐⭐ 맛있다</p>">
<p>김지웅</p>
<p>OO동 XX집</p>
</div>
</div>
<div class="fav-res"><!--박스 5-->
<div class="fav-res-box">
<p>맛집 5</p>
</div>
</div>
<div class="fav-res"><!--박스 6-->
<div class="fav-res-box">
<p>맛집 6</p>
</div>
</div>
</div>
<div id="modal">
<div id="modal-close">
×
</div>
<div id="modal-content">
</div>
</div>
</div>
</body>
</html>
.favorite-restaurant {
width: 1280px;
margin-left: 450px;
margin-right: 50px;
display: grid;
}
.fav-res-subtitle {
grid-column: span 3;
border: 3px solid #ff3d00;
border-radius: 40px;
margin: 0 auto;
width: 500px;
height: 100px;
font-size: 40px;
text-align: center;
line-height: 15px;
}
팀명과 네비게이션 메뉴를 제외한 컨텐츠 구역인 favorite-restaurant
에 grid를 넣고, fav-res-subtitle
이라고 지은 제목에 grid-colum: span 3;
을 넣어서, 제목 클래스가 3개의 열을 차지하도록 설정했다.
이 속성을 사용함으로써, 자연스럽게 다른 행들도 3개씩 한줄로 배치되었다.
문제점
그런데 창을 줄이면 위 사진과 같이 모달이 전부 보이지 않고 스크롤을 내려도 계속해서 따라와, 모달창을 전부 볼 수 없다.
#modal {
display: none;
background-color: yellowgreen;
width: 600px;
height: 500px;
overflow-y: auto;
margin: auto;
padding: 0 15px 0 15px;
position: fixed;
transform: translate(125%, -98%);
border-radius: 50px;
}
아직 확신을 하진 못하지만 transform: translate(125%, -98%);
이 설정때문일지도 모르겠다.
내일 이 문제를 해결하고 다른 팀원들꺼 병합해서 네비게이션 클릭시 컨텐츠만 바뀌는 걸 알아봐야겠다.
+ 오늘 못들은 깃허브 강의
오늘 배운것
모달창
<script>
document.addEventListener("DOMContentLoaded",() => {
const modal = document.getElementById("modal");
const modalContent = document.getElementById('modal-content')
function modalOn(content) {
modalContent.innerHTML = content;
modal.style.display = "flex";
} // 모달 켜는 함수
function modalOff() {
modal.style.display = "none";
} // 모달 종료 함수
const clickModal = document.querySelectorAll(".fav-res-box"); // fav-res-box 클래스를 가진 모든 요소 선택
clickModal.forEach(clic =>{
clic.addEventListener("click", () => {
const content = clic.getAttribute("data-content");
modalOn(content);
}) // 클릭 시 data불러오고 모달 켜는 함수 실행되도록
}) // 여러개의 요소가 있기때문에 forEach로 반복
const closeModal = document.getElementById("modal-close");
closeModal.addEventListener("click", modalOff); // 클릭 시 모달 종료 함수 실행
})
</script>
물론 어제 작성한거지만 오늘도 잘 이해 안되는것 몇번 더 봤다.
마우스 올리면 밑줄 생기게 하기
#modal a {
color:aquamarine;
}
#modal a:hover {
text-decoration: underline;
}
grid 배열과 한줄에 있을 요소 개수 정하기
.favorite-restaurant {
width: 1280px;
margin-left: 450px;
margin-right: 50px;
display: grid;
}
.fav-res-subtitle {
grid-column: span 3;
border: 3px solid #ff3d00;
border-radius: 40px;
margin: 0 auto;
width: 500px;
height: 100px;
font-size: 40px;
text-align: center;
line-height: 15px;
}
컨텐츠 전체에 grid를 적용하고 제목이 3개의 영역을 먹도록 해서, 1줄에 3개씩 배치되도록.
grid-column
을 요소 박스에 직접 넣어도 가능할 듯.
요소 겹치기
#modal {
display: none;
background-color: yellowgreen;
width: 600px;
height: 500px;
overflow-y: auto;
margin: auto;
padding: 0 15px 0 15px;
position: fixed;
transform: translate(125%, -98%);
border-radius: 50px;
} /* 모달창 */
position: fixed
를 통해 요소를 겹쳐서 놓을 수 있었다.