Bootstrap - Plugin Popover

Popover mirip dengan tooltip, menawarkan tampilan yang diperluas lengkap dengan judul. Agar popover diaktifkan, pengguna hanya perlu mengarahkan kursor ke elemen. Konten popover dapat diisi seluruhnya menggunakan API Data Bootstrap. Metode ini membutuhkan keterangan alat.

Jika Anda ingin memasukkan fungsionalitas plugin ini satu per satu, maka Anda memerlukan popover.jsdan memiliki ketergantungan plugin tooltip . Lain, seperti yang disebutkan dalam bab Bootstrap Plugins Sekilas , Anda dapat menyertakan bootstrap.js atau minified bootstrap.min.js .

Pemakaian

Plugin popover menghasilkan konten dan markup sesuai permintaan, dan secara default menempatkan popover setelah elemen pemicunya. Anda dapat menambahkan popover dengan dua cara berikut -

  • Via data attributes - Untuk menambahkan popover, tambahkan data-toggle = "popover"ke tag jangkar / tombol. Judul jangkar akan menjadi teks popover. Secara default, popover diatur ke atas oleh plugin.

<a href = "#" data-toggle = "popover" title = "Example popover">
   Hover over me
</a>
  • Via JavaScript - Aktifkan popovers melalui JavaScript menggunakan sintaks berikut -

$('#identifier').popover(options)

Plugin popover BUKAN hanya plugin css seperti dropdown atau plugin lain yang dibahas pada bab sebelumnya. Untuk menggunakan plugin ini Anda HARUS mengaktifkannya menggunakan jquery (baca javascript). Untuk mengaktifkan semua popovers di halaman Anda, cukup gunakan skrip ini -

$(function () { $("[data-toggle = 'popover']").popover(); });

Contoh

Contoh berikut menunjukkan penggunaan plugin popover melalui atribut data.

<div class = "container" style = "padding: 100px 50px 10px;" >
   <button type = "button" class = "btn btn-default" title = "Popover title"  
      data-container = "body" data-toggle = "popover" data-placement = "left" 
      data-content = "Some content in Popover on left">
      
      Popover on left
   </button>
   
   <button type = "button" class = "btn btn-primary" title = "Popover title"  
      data-container = "body" data-toggle = "popover" data-placement = "top" 
      data-content = "Some content in Popover on top">
      
      Popover on top
   </button>
   
   <button type = "button" class = "btn btn-success" title = "Popover title"  
      data-container = "body" data-toggle = "popover" data-placement = "bottom" 
      data-content = "Some content in Popover on bottom">
      
      Popover on bottom
   </button>
   
   <button type = "button" class = "btn btn-warning" title = "Popover title"  
      data-container = "body" data-toggle = "popover" data-placement = "right" 
      data-content = "Some content in Popover on right">
      
      Popover on right
   </button>
   
</div>

<script>
   $(function (){
      $("[data-toggle = 'popover']").popover();
   });
</script>

Pilihan

Ada opsi tertentu yang dapat ditambahkan melalui Bootstrap Data API atau dipanggil melalui JavaScript. Tabel berikut mencantumkan opsi -

Nama Opsi Jenis / Nilai Default Nama atribut data Deskripsi
animasi boolean Default - benar data-animasi Menerapkan transisi pemudaran CSS ke popover.
html boolean Default - salah data-html Menyisipkan HTML ke dalam popover. Jika salah, metode teks jQuery akan digunakan untuk memasukkan konten ke dalam dom. Gunakan teks jika Anda khawatir tentang serangan XSS.
penempatan string | fungsi Default - atas penempatan data Menentukan bagaimana memposisikan popover (yaitu, atas | bawah | kiri | kanan | otomatis). Ketika otomatis ditentukan, itu akan secara dinamis mengubah orientasi popover. Misalnya, jika penempatannya "kiri otomatis", popover akan ditampilkan ke kiri bila memungkinkan, jika tidak maka akan ditampilkan ke kanan.
pemilih string Default - salah pemilih data Jika pemilih disediakan, objek popover akan didelegasikan ke target yang ditentukan.
judul string | fungsi Default - " data-title Opsi judul adalah nilai judul default jika atribut judul tidak ada.
pelatuk string Default - 'arahkan kursor' pemicu data Mendefinisikan bagaimana popover dipicu - click| hover | focus | manual. Anda mungkin melewatkan beberapa pemicu; pisahkan dengan spasi.
menunda nomor | objek Default - 0 penundaan data

Penundaan menampilkan dan menyembunyikan popover dalam md - tidak berlaku untuk jenis pemicu manual. Jika nomor disediakan, penundaan diterapkan ke kedua sembunyikan / tampilkan. Struktur objek adalah -

delay: { show: 500, hide: 100 }
wadah string | false Default - salah wadah data Menambahkan popover ke elemen tertentu. Contoh: container: 'body'

Metode

Berikut ini adalah beberapa metode berguna untuk popover -

metode Deskripsi Contoh

Options - .popover (opsi)

Melampirkan penangan popover ke koleksi elemen.
$().popover(options)

Toggle - .popover ('toggle')

Mengalihkan popover elemen.
$('#element').popover('toggle')

Show - .popover ('show')

Mengungkap popover elemen.
$('#element').popover('show')

Hide - .popover ('sembunyikan')

Menyembunyikan popover elemen.
$('#element').popover('hide')

Destroy - .popover ('hancurkan')

Menyembunyikan dan menghancurkan popover elemen.
$('#element').popover('destroy')

Contoh

Contoh berikut menunjukkan metode plugin popover -

<div class = "container" style = "padding: 100px 50px 10px;" >
   <button type = "button" class = "btn btn-default popover-show" 
      title = "Popover title" data-container = "body" 
      data-toggle = "popover" data-placement = "left" 
      data-content = "Some content in Popover with show method">
      
      Popover on left
   </button>
   
   <button type = "button" class = "btn btn-primary popover-hide" 
      title = "Popover title" data-container = "body" 
      data-toggle = "popover" data-placement = "top" 
      data-content = "Some content in Popover-hide method">
      
      Popover on top
   </button>
   
   <button type = "button" class = "btn btn-success popover-destroy" 
      title = "Popover title" data-container = "body" 
      data-toggle = "popover" data-placement = "bottom" 
      data-content = "Some content in Popover-destroy method">
      
      Popover on bottom
   </button>
   
   <button type = "button" class = "btn btn-warning popover-toggle" 
      title = "Popover title" data-container = "body" 
      data-toggle = "popover" data-placement = "top" 
      data-content = "Some content in Popover-toggle method">
      
      Popover on right
   </button>
	
   <br><br><br><br><br><br>
   
   <p class = "popover-options">
      <a href = "#" type = "button" class = "btn btn-warning" 
         title = "<h2>Title</h2>" data-container = "body" 
         data-toggle = "popover" data-content = "
         <h4>Some content in Popover-options method</h4>">
         
         Popover
      </a>
   </p>
   
   <script>
      $(function () { $('.popover-show').popover('show');});
      $(function () { $('.popover-hide').popover('hide');});
      $(function () { $('.popover-destroy').popover('destroy');});
      $(function () { $('.popover-toggle').popover('toggle');});
      $(function () { $(".popover-options a").popover({html : true });});
   </script>
	
</div>

Acara

Tabel berikut mencantumkan acara untuk bekerja dengan plugin popover. Acara ini dapat digunakan untuk menghubungkan ke fungsi tersebut.

Peristiwa Deskripsi Contoh
show.bs.popover Peristiwa ini segera dijalankan ketika metode contoh acara dipanggil.
$('#mypopover').on('show.bs.popover', function () {
   // do something
})
ditampilkan. bs.popover Peristiwa ini dijalankan saat popover dibuat terlihat oleh pengguna (akan menunggu transisi CSS selesai).
$('#mypopover').on('shown.bs.popover', function () {
   // do something
})
hide.bs.popover Peristiwa ini dijalankan segera ketika metode instance hide telah dipanggil.
$('#mypopover').on('hide.bs.popover', function () {
   // do something
})
hidden.bs.popover Peristiwa ini dijalankan ketika popover selesai disembunyikan dari pengguna (akan menunggu transisi CSS selesai).
$('#mypopover').on('hidden.bs.popover', function () {
   // do something
})

Contoh

Contoh berikut menunjukkan acara plugin Popover -

<div clas = "container" style = "padding: 100px 50px 10px;" >
   <button type = "button" class = "btn btn-primary popover-show" 
      title = "Popover title" data-container = "body" data-toggle = "popover" 
      data-content = "Some content in Popover with show method">
      
      Popover on left
   </button>
   
</div>

<script>
   $(function () { $('.popover-show').popover('show');});
   
   $(function () { $('.popover-show').on('shown.bs.popover', function () {
      alert("Alert message on show");
   })});
</script>