부트 스트랩-플러그인 개요

이전 장에서 설명한 구성 요소 Layout Components시작에 불과합니다. Bootstrap은 기능을 확장하고 사이트에 더 많은 상호 작용을 추가 할 수있는 12 개의 jQuery 플러그인과 함께 번들로 제공됩니다. Bootstrap의 JavaScript 플러그인을 시작하기 위해 고급 JavaScript 개발자가 아니어도됩니다. 부트 스트랩 데이터 API를 활용하면 대부분의 플러그인이 한 줄의 코드를 작성하지 않고도 트리거 될 수 있습니다.

부트 스트랩 플러그인은 두 가지 형태로 사이트에 포함될 수 있습니다.

  • Individually− Bootstrap의 개별 * .js 파일 사용. 일부 플러그인 및 CSS 구성 요소는 다른 플러그인에 의존합니다. 플러그인을 개별적으로 포함하는 경우 문서에서 이러한 종속성을 확인하십시오.

  • 또는 compiled (all at once)bootstrap.js 또는 축소 된 bootstrap.min.js 사용 . bootstrap.jsbootstrap.min.js 는 모두 단일 파일에 모든 플러그인을 포함 하므로 둘 다 포함하지 마십시오 .

모든 플러그인은 jQuery에 의존합니다. 따라서 jQuery는 플러그인 파일 앞에 포함되어야합니다. bower.json 을 확인 하여 지원되는 jQuery 버전을 확인하십시오.

데이터 속성

  • 포함 된 데이터 API를 사용하여 모든 부트 스트랩 플러그인에 액세스 할 수 있습니다. 따라서 플러그인 기능을 호출하기 위해 한 줄의 JavaScript를 포함 할 필요가 없습니다.

  • 경우에 따라 데이터 API의이 기능을 해제하는 것이 바람직 할 수 있습니다. 데이터 API를 꺼야하는 경우 다음 JavaScript 행을 추가하여 속성을 바인딩 해제 할 수 있습니다.

$(document).off('.data-api')
  • 특정 / 단일 플러그인을 끄려면 다음과 같이 data-api 네임 스페이스와 함께 플러그인의 이름을 네임 스페이스로 포함하면됩니다.

$(document).off('.alert.data-api')

프로그래밍 방식 API

Bootstrap 개발자는 JavaScript API를 통해서만 모든 플러그인을 사용할 수 있어야한다고 생각합니다. 모든 공용 API는 단일, 체인 가능한 메소드이며 예를 들어 조치 된 컬렉션을 반환합니다.

$(".btn.danger").button("toggle").addClass("fat")

모든 메소드는 선택적 옵션 객체, 특정 메소드를 대상으로하는 문자열 또는 아래에 표시된대로 아무것도 허용하지 않습니다 (기본 동작으로 플러그인을 시작 함).

// initialized with defaults
$("#myModal").modal()    

 // initialized with no keyboard                  
$("#myModal").modal({ keyboard: false })  

// initializes and invokes show immediately
$("#myModal").modal('show')

각 플러그인은 또한 원시 생성자를 Constructor속성 : $ .fn.popover.Constructor . 특정 플러그인 인스턴스를 얻으려면 요소에서 직접 검색하십시오.

$('[rel = popover]').data('popover').

충돌 없음

Bootstrap 플러그인은 때때로 다른 UI 프레임 워크와 함께 사용할 수 있습니다. 이러한 상황에서 네임 스페이스 충돌이 가끔 발생할 수 있습니다. 이 부름을 극복하기 위해.noConflict 값을 되돌리려는 플러그인에서.

// return $.fn.button to previously assigned value
var bootstrapButton = $.fn.button.noConflict()

// give $().bootstrapBtn the Bootstrap functionality
$.fn.bootstrapBtn = bootstrapButton

이벤트

부트 스트랩은 대부분의 플러그인 고유 작업에 대한 사용자 지정 이벤트를 제공합니다. 일반적으로 이러한 이벤트는 두 가지 형태로 나타납니다.

  • Infinitive form− 이것은 이벤트가 시작될 때 트리거됩니다. 예 : show . 부정사 이벤트는 preventDefault 기능을 제공 합니다. 이를 통해 시작하기 전에 작업 실행을 중지 할 수 있습니다.

$('#myModal').on('show.bs.modal', function (e) {
   // stops modal from being shown
   if (!data) return e.preventDefault() 
})
  • Past participle form− 이것은 작업이 완료되면 트리거됩니다. 예 :