부트 스트랩-모달 플러그인
모달은 부모 창 위에 겹쳐진 자식 창입니다. 일반적으로 목적은 상위 창을 벗어나지 않고 상호 작용할 수있는 별도의 소스에서 콘텐츠를 표시하는 것입니다. 자식 창은 정보, 상호 작용 등을 제공 할 수 있습니다.
이 플러그인 기능을 개별적으로 포함하려면 다음이 필요합니다. modal.js. 그렇지 않으면 Bootstrap Plugins Overview 장에서 언급했듯이 bootstrap.js 또는 축소 된 bootstrap.min.js를 포함 할 수 있습니다 .
용법
모달 플러그인의 숨겨진 콘텐츠를 전환 할 수 있습니다.
Via data attributes − 속성 설정 data-toggle = "modal" 버튼이나 링크와 같은 컨트롤러 요소에 data-target = "#identifier" 또는 href = "#identifier" 토글 할 특정 모달 (id = "식별자")을 대상으로 지정합니다.
Via JavaScript −이 기술을 사용하면 한 줄의 JavaScript로 id = "identifier"인 모달을 호출 할 수 있습니다. −
$('#identifier').modal(options)
예
정적 모달 창 예는 다음 예에 나와 있습니다.
<h2>Example of creating Modals with Twitter Bootstrap</h2>
<!-- Button trigger modal -->
<button class = "btn btn-primary btn-lg" data-toggle = "modal" data-target = "#myModal">
Launch demo modal
</button>
<!-- Modal -->
<div class = "modal fade" id = "myModal" tabindex = "-1" role = "dialog"
aria-labelledby = "myModalLabel" aria-hidden = "true">
<div class = "modal-dialog">
<div class = "modal-content">
<div class = "modal-header">
<button type = "button" class = "close" data-dismiss = "modal" aria-hidden = "true">
×
</button>
<h4 class = "modal-title" id = "myModalLabel">
This Modal title
</h4>
</div>
<div class = "modal-body">
Add some text here
</div>
<div class = "modal-footer">
<button type = "button" class = "btn btn-default" data-dismiss = "modal">
Close
</button>
<button type = "button" class = "btn btn-primary">
Submit changes
</button>
</div>
</div><!-- /.modal-content -->
</div><!-- /.modal-dialog -->
</div><!-- /.modal -->
Details of the preceding code −
모달 창을 호출하려면 일종의 트리거가 있어야합니다. 버튼이나 링크를 사용할 수 있습니다. 여기서는 버튼을 사용했습니다.
위의 코드를 보면 <button> 태그에서 data-target = "#myModal"페이지에로드하려는 모달의 대상입니다. 이 코드를 사용하면 페이지에서 여러 모달을 만든 다음 각 모달에 대해 다른 트리거를 가질 수 있습니다. 이제 명확하게 말하면 여러 모달을 동시에로드하지 않지만 페이지에 여러 모달을 만들어 다른 시간에로드 할 수 있습니다.
모달에서 주목해야 할 두 가지 클래스가 있습니다.
첫 번째는 .modal, 이는 단순히 <div>의 내용을 모달로 식별하는 것입니다.
그리고 두 번째는 .fade수업. 모달이 토글되면 콘텐츠가 페이드 인 및 페이드 아웃됩니다.
aria-labelledby = "myModalLabel", 속성은 모달 제목을 참조합니다.
속성 aria-hidden = "true" 트리거가 올 때까지 모달 창을 보이지 않게 유지하는 데 사용됩니다 (예 : 관련 버튼 클릭).
<div class = "modal-header">, modal-header는 모달 창의 헤더 스타일을 정의하는 클래스입니다.
class = "close"는 모달 창의 닫기 버튼에 대한 스타일을 설정하는 CSS 클래스 닫기입니다.
data-dismiss = "modal"은 맞춤 HTML5 데이터 속성입니다. 여기서는 모달 창을 닫는 데 사용됩니다.
class = "modal-body", 모달 창의 본문 스타일을 설정하는 Bootstrap CSS의 CSS 클래스입니다.
class = "modal-footer"는 모달 창의 바닥 글 스타일을 설정하는 Bootstrap CSS의 CSS 클래스입니다.
data-toggle = "modal", HTML5 사용자 정의 데이터 속성 data-toggle은 모달 창을 여는 데 사용됩니다.
옵션
모달 창의 모양과 느낌을 사용자 정의하기 위해 데이터 속성 또는 JavaScript를 통해 전달할 수있는 특정 옵션이 있습니다. 다음 표에는 옵션이 나열되어 있습니다.
옵션 이름 | 유형 / 기본값 | 데이터 속성 이름 | 기술 |
---|---|---|---|
배경 | 부울 또는 '정적'문자열 기본값 : true | 데이터 배경 | 사용자가 모달 외부를 클릭 할 때 모달이 닫히지 않도록하려면 배경에 정적을 지정하십시오. |
건반 | 부울 기본값 : true | 데이터 키보드 | 이스케이프 키를 누르면 모달을 닫습니다. 비활성화하려면 false로 설정합니다. |
보여 주다 | 부울 기본값 : true | 데이터 쇼 | 초기화되면 모달을 표시합니다. |
먼 | 경로 기본값 : false | 데이터 원격 | jQuery .load 메서드를 사용하여 모달 본문에 콘텐츠를 삽입합니다. 유효한 URL이있는 href가 추가되면 해당 콘텐츠가로드됩니다. 이에 대한 예가 아래에 나와 있습니다. |
행동 양식
다음은 modal ()과 함께 사용할 수있는 몇 가지 유용한 메서드입니다.
방법 | 기술 | 예 |
---|---|---|
Options − .modal (옵션) | 콘텐츠를 모달로 활성화합니다. 선택적 옵션 개체를 허용합니다. | |
Toggle − .modal ( 'toggle') | 모달을 수동으로 전환합니다. | |
Show − .modal ( 'show') | 모달을 수동으로 엽니 다. | |
Hide − .modal ( 'hide') | 모달을 수동으로 숨 깁니다. | |
예
다음 예제는 방법의 사용법을 보여줍니다-
<h2>Example of using methods of Modal Plugin</h2>
<!-- Button trigger modal -->
<button class = "btn btn-primary btn-lg" data-toggle = "modal" data-target = "#myModal">
Launch demo modal
</button>
<!-- Modal -->
<div class = "modal fade" id = "myModal" tabindex = "-1" role = "dialog"
aria-labelledby = "myModalLabel" aria-hidden = "true">
<div class = "modal-dialog">
<div class = "modal-content">
<div class = "modal-header">
<button type = "button" class = "close" data-dismiss = "modal" aria-hidden = "true">
×
</button>
<h4 class = "modal-title" id = "myModalLabel">
This Modal title
</h4>
</div>
<div class = "modal-body">
Press ESC button to exit.
</div>
<div class = "modal-footer">
<button type = "button" class = "btn btn-default" data-dismiss = "modal">
Close
</button>
<button type = "button" class = "btn btn-primary">
Submit changes
</button>
</div>
</div><!-- /.modal-content -->
</div><!-- /.modal-dialog -->
</div><!-- /.modal -->
<script>
$(function () { $('#myModal').modal({
keyboard: true
})});
</script>
Esc 버튼을 클릭하면 모달 창이 종료됩니다.
이벤트
다음 표는 모달에서 작동하는 이벤트를 나열합니다. 이러한 이벤트는 함수에 연결하는 데 사용할 수 있습니다.
행사 | 기술 | 예 |
---|---|---|
show.bs.modal | show 메서드가 호출 된 후 시작됩니다. | |
shown.bs.modal | 모달이 사용자에게 표시되면 시작됩니다 (CSS 전환이 완료 될 때까지 기다립니다). | |
hide.bs.modal | hide 인스턴스 메서드가 호출되면 시작됩니다. | |
hidden.bs.modal | 모달이 사용자에게 표시되지 않으면 시작됩니다. | |
예
다음 예제는 이벤트의 사용법을 보여줍니다-
<h2>Example of using events of Modal Plugin</h2>
<!-- Button trigger modal -->
<button class = "btn btn-primary btn-lg" data-toggle = "modal" data-target = "#myModal">
Launch demo modal
</button>
<!-- Modal -->
<div class = "modal fade" id = "myModal" tabindex = "-1" role = "dialog"
aria-labelledby = "myModalLabel" aria-hidden = "true">
<div class = "modal-dialog">
<div class = "modal-content">
<div class = "modal-header">
<button type = "button" class = "close" data-dismiss = "modal" aria-hidden = "true">
×
</button>
<h4 class = "modal-title" id = "myModalLabel">
This Modal title
</h4>
</div>
<div class = "modal-body">
Click on close button to check Event functionality.
</div>
<div class = "modal-footer">
<button type = "button" class = "btn btn-default" data-dismiss = "modal">
Close
</button>
<button type = "button" class = "btn btn-primary">
Submit changes
</button>
</div>
</div><!-- /.modal-content -->
</div><!-- /.modal-dialog -->
</div><!-- /.modal -->
<script>
$(function () { $('#myModal').modal('hide')})});
</script>
<script>
$(function () { $('#myModal').on('hide.bs.modal', function () {
alert('Hey, I heard you like modals...');})
});
</script>
위 화면과 같이 닫기 버튼 ( 이벤트 숨기기) 을 클릭 하면 경고 메시지가 표시됩니다.