모달 적용하기

오늘은 팀장님이 만든 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="팀 소개">&nbsp;팀 소개</a></li>
                    <li><img class="labtop" src="labtop.png"><a href="#" title="멤버 소개"> &nbsp;멤버 소개</a></li>
                    <li><img class="book" src="book.png"><a href="#" title="방명록"> &nbsp;방명록</a></li>
                    <li><img class="ping" src="ping.png"><a href="#" title="멤버들이 추천하는 맛집"> &nbsp;멤버들이 추천하는 맛집</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">
                &times;
            </div>
            <div id="modal-content">
            </div>
        </div>
    </div>
</body>

</html>

page

open-modal

        .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개씩 한줄로 배치되었다.



문제점

error-modal

그런데 창을 줄이면 위 사진과 같이 모달이 전부 보이지 않고 스크롤을 내려도 계속해서 따라와, 모달창을 전부 볼 수 없다.

        #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를 통해 요소를 겹쳐서 놓을 수 있었다.

태그:

카테고리:

업데이트: