본문 바로가기
코딩(php,javascript,mysql)

업무 편람과 일지를 위한 부트스트랩 모달 제작 가이드

by mylife365 2024. 12. 29.

업무 편람과 일지를 위한 부트스트랩 모달 제작 가이드

웹 프로젝트에서 정보를 깔끔하고 사용자 친화적으로 표시하는 방법 중 하나는 모달 창을 활용하는 것입니다. 특히 부트스트랩 모달은 설정과 커스터마이징이 쉬워 많은 개발자들이 선호하는 도구입니다. 이번 글에서는 업무 편람 및 일지 시스템을 제작할 때 사용할 수 있는 부트스트랩 기반의 모달 창을 구현하는 방법을 친절하게 설명하겠습니다. 초보자도 따라 하기 쉽게 단계별로 안내합니다.

 


1. 기본 모달 구조

모달은 화면에 떠오르는 창으로, 메인 콘텐츠를 가리지 않고 필요한 정보를 표시할 수 있습니다. 먼저 모달의 기본 HTML 구조를 살펴보겠습니다.

<!-- todosMain 모달 컨테이너 -->
<div class="container-fluid">
	<!-- Modal -->
	<div id="todosMainModal" class="modal" style="z-index: 1050; display: block;">
		<div class="modal-dialog modal-dialog-scrollable modal-fullscreen" role="document">
			<div class="modal-content">
				<div class="modal-header">
					<h5 class="modal-title">업무편람/일지</h5>
					<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
				</div>
				<div class="modal-body todosMain_modal-body">
					<p>모달 내용이 여기에 표시됩니다.</p>
				</div>
			</div>
		</div>
	</div>
</div>

구조 설명

  1. container-fluid: 전체 화면 크기를 차지하는 컨테이너입니다.
  2. modal: 부트스트랩 모달을 정의하는 클래스입니다.
  3. modal-dialog: 모달의 크기와 스크롤 가능 여부를 설정합니다.
    • modal-dialog-scrollable: 모달 내용이 길어질 경우 스크롤을 활성화합니다.
    • modal-fullscreen: 모달을 화면 전체 크기로 확장합니다.
  4. modal-content: 모달의 콘텐츠를 포함하는 영역입니다.
  5. modal-header: 모달의 제목과 닫기 버튼이 포함된 헤더 영역입니다.
  6. modal-body: 모달 본문의 내용을 표시합니다.

2. 스타일링 모달

HTML 구조만으로는 완성된 UI를 만들 수 없습니다. 모달을 시각적으로 돋보이게 하려면 CSS를 활용해야 합니다. 아래는 모달을 스타일링하기 위한 CSS 코드입니다.

.modal {
    z-index: 1050;
    display: block;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    background-color: rgba(0, 0, 0, 0.6); /* 어두운 배경 */
}

.modal-dialog {
    margin: auto;
    max-width: 1200px;
    border-radius: 10px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.3); /* 그림자 효과 */
}

.modal-header {
    background-color: #1f48d4;
    color: white;
    padding: 10px;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}

.modal-body {
    padding: 15px;
    background-color: #f9f9f9;
}

.btn-close {
    color: white;
    font-size: 18px;
    font-weight: bold;
    cursor: pointer;
}

주요 스타일링 요소

  • 배경색: background-color: rgba(0, 0, 0, 0.6);를 사용해 모달 배경을 어두운 반투명 색상으로 설정하여 콘텐츠가 강조되도록 했습니다.
  • 모서리 둥글게: border-radius: 10px;를 사용해 모달 창의 모서리를 부드럽게 표현했습니다.
  • 그림자 효과: box-shadow 속성으로 모달이 떠 있는 느낌을 줍니다.

3. 동작 구현

모달은 기본적으로 숨겨진 상태로 시작하며, JavaScript로 표시하거나 숨길 수 있습니다. 아래는 jQuery를 사용해 모달을 제어하는 코드입니다.

// 모달 표시
$("#todosMainModal").modal('show');

// 모달 숨기기
$("#todosMainModal").modal('hide');

직접 제어

만약 부트스트랩의 기본 메서드 대신 직접 제어하려면 CSS 속성을 사용하여 display 속성을 변경할 수 있습니다.

document.querySelector("#todosMainModal").style.display = "block"; // 모달 표시
document.querySelector("#todosMainModal").style.display = "none"; // 모달 숨기기

4. 반응형 디자인

모달이 모든 화면 크기에서 적절히 표시되도록 반응형 디자인을 적용할 수 있습니다. 부트스트랩의 반응형 유틸리티 클래스를 사용하여 화면 크기에 따라 모달 크기를 조정합니다.

<div class="modal-dialog modal-xl"> <!-- 더 큰 화면 -->
<div class="modal-dialog modal-lg"> <!-- 중간 화면 -->
<div class="modal-dialog modal-sm"> <!-- 작은 화면 -->

5. 모달과 배경의 충돌 방지

모달이 사이드바나 다른 요소 뒤로 숨겨지는 문제를 방지하려면 z-index를 조정해야 합니다. 모달과 배경의 z-index 값을 명확히 설정하면 이 문제를 해결할 수 있습니다.

.modal {
    z-index: 1050; /* 모달의 z-index 설정 */
}

.sidebar {
    z-index: 1000; /* 사이드바의 z-index를 낮게 설정 */
}

이 설정을 통해 모달이 항상 최상단에 표시되며, 다른 UI 요소와 충돌하지 않도록 보장할 수 있습니다.


부트스트랩 모달은 간단한 코드와 약간의 스타일링으로도 강력한 사용자 경험을 제공합니다. 업무 편람 및 일지 같은 복잡한 시스템에서도 직관적이고 깔끔한 인터페이스를 구현할 수 있습니다. 위의 코드를 활용해 자신만의 모달 창을 완성해 보세요!

반응형