부트 스트랩-모달 플러그인

모달은 부모 창 위에 겹쳐진 자식 창입니다. 일반적으로 목적은 상위 창을 벗어나지 않고 상호 작용할 수있는 별도의 소스에서 콘텐츠를 표시하는 것입니다. 자식 창은 정보, 상호 작용 등을 제공 할 수 있습니다.

이 플러그인 기능을 개별적으로 포함하려면 다음이 필요합니다. 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">
                  &times;
            </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가 추가되면 해당 콘텐츠가로드됩니다. 이에 대한 예가 아래에 나와 있습니다.

<a data-toggle = "modal" href = "remote.html" data-target = "#modal">Click me</a>

행동 양식

다음은 modal ()과 함께 사용할 수있는 몇 가지 유용한 메서드입니다.

방법 기술
Options − .modal (옵션) 콘텐츠를 모달로 활성화합니다. 선택적 옵션 개체를 허용합니다.
$('#identifier').modal({
   keyboard: false
})
Toggle − .modal ( 'toggle') 모달을 수동으로 전환합니다.
$('#identifier').modal('toggle')
Show − .modal ( 'show') 모달을 수동으로 엽니 다.
$('#identifier').modal('show')
Hide − .modal ( 'hide') 모달을 수동으로 숨 깁니다.
$('#identifier').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 메서드가 호출 된 후 시작됩니다.
$('#identifier').on('show.bs.modal', function () {
   // do something…
})
shown.bs.modal 모달이 사용자에게 표시되면 시작됩니다 (CSS 전환이 완료 될 때까지 기다립니다).
$('#identifier').on('shown.bs.modal', function () {
   // do something…
})
hide.bs.modal hide 인스턴스 메서드가 호출되면 시작됩니다.
$('#identifier').on('hide.bs.modal', function () {
   // do something…
})
hidden.bs.modal 모달이 사용자에게 표시되지 않으면 시작됩니다.
$('#identifier').on('hidden.bs.modal', function () {
   // do something…
})

다음 예제는 이벤트의 사용법을 보여줍니다-

<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>

위 화면과 같이 닫기 버튼 ( 이벤트 숨기기) 을 클릭 하면 경고 메시지가 표시됩니다.