Modal
Gamitin ang JavaScript modal plugin ng Bootstrap upang magdagdag ng mga dialog sa iyong site para sa mga lightbox, notification ng user, o ganap na custom na content.
Bago magsimula sa modal component ng Bootstrap, siguraduhing basahin ang mga sumusunod dahil ang aming mga opsyon sa menu ay nagbago kamakailan.
- Ang mga modal ay binuo gamit ang HTML, CSS, at JavaScript. Ang mga ito ay nakaposisyon sa lahat ng iba pa sa dokumento at alisin ang scroll mula sa
<body>
upang ang modal na nilalaman ay mag-scroll sa halip. - Ang pag-click sa modal na "backdrop" ay awtomatikong isasara ang modal.
- Sinusuportahan lamang ng Bootstrap ang isang modal window sa isang pagkakataon. Hindi sinusuportahan ang mga nested modal dahil naniniwala kami na ang mga ito ay hindi magandang karanasan ng user.
- Ginagamit ang mga modal
position: fixed
, na kung minsan ay medyo partikular sa pag-render nito. Hangga't maaari, ilagay ang iyong modal HTML sa isang top-level na posisyon upang maiwasan ang potensyal na interference mula sa iba pang mga elemento. Malamang na magkakaroon ka ng mga isyu kapag nag-nest ng isang sa.modal
loob ng isa pang nakapirming elemento. - Muli, dahil sa
position: fixed
, may ilang mga caveat sa paggamit ng mga modal sa mga mobile device. Tingnan ang aming browser support docs para sa mga detalye. - Dahil sa kung paano tinukoy ng HTML5 ang mga semantika nito, ang
autofocus
HTML attribute ay walang epekto sa Bootstrap modals. Upang makamit ang parehong epekto, gumamit ng ilang custom na JavaScript:
Panatilihin ang pagbabasa para sa mga demo at mga alituntunin sa paggamit.
Nasa ibaba ang isang static na halimbawa ng modal (ibig sabihin nito position
at display
na-override na). Kasama ang modal header, modal body (kinakailangan para sa padding
), at modal footer (opsyonal). Hinihiling namin na isama mo ang mga modal header na may mga pagkilos na i-dismiss hangga't maaari, o magbigay ng isa pang tahasang pagkilos sa pag-dismiss.
I-toggle ang gumaganang modal demo sa pamamagitan ng pag-click sa button sa ibaba. Magda-slide ito pababa at maglalaho mula sa itaas ng page.
Kapag masyadong mahaba ang mga modal para sa viewport o device ng user, nag-i-scroll sila nang hiwalay sa mismong page. Subukan ang demo sa ibaba upang makita kung ano ang ibig naming sabihin.
Idagdag .modal-dialog-centered
sa .modal-dialog
patayo na igitna ang modal.
Ang mga tooltip at popover ay maaaring ilagay sa loob ng mga modal kung kinakailangan. Kapag isinara ang mga modal, awtomatikong dini-dismiss din ang anumang tooltip at popover sa loob.
Gamitin ang Bootstrap grid system sa loob ng isang modal sa pamamagitan ng pagpupugad sa .container-fluid
loob ng .modal-body
. Pagkatapos, gamitin ang normal na mga klase ng sistema ng grid gaya ng gagawin mo saanman.
May isang grupo ng mga pindutan na lahat ay nagpapalitaw ng parehong modal na may bahagyang magkakaibang mga nilalaman? Gamitin event.relatedTarget
at HTML na mga data-*
katangian (maaaring sa pamamagitan ng jQuery ) upang pag-iba-ibahin ang mga nilalaman ng modal depende sa kung aling button ang na-click.
Nasa ibaba ang isang live na demo na sinusundan ng halimbawang HTML at JavaScript. Para sa higit pang impormasyon, basahin ang mga modal event docs para sa mga detalye sa relatedTarget
.
<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal" data-whatever="@mdo">Open modal for @mdo</button>
<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal" data-whatever="@fat">Open modal for @fat</button>
<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal" data-whatever="@getbootstrap">Open modal for @getbootstrap</button>
<div class="modal fade" id="exampleModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">New message</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body">
<form>
<div class="form-group">
<label for="recipient-name" class="col-form-label">Recipient:</label>
<input type="text" class="form-control" id="recipient-name">
</div>
<div class="form-group">
<label for="message-text" class="col-form-label">Message:</label>
<textarea class="form-control" id="message-text"></textarea>
</div>
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary">Send message</button>
</div>
</div>
</div>
</div>
Para sa mga modal na lilitaw lamang sa halip na mawala upang tingnan, alisin ang .fade
klase sa iyong modal markup.
Kung nagbabago ang taas ng isang modal habang ito ay bukas, dapat kang tumawag $('#myModal').modal('handleUpdate')
upang muling ayusin ang posisyon ng modal kung sakaling lumitaw ang isang scrollbar.
Siguraduhing magdagdag role="dialog"
at aria-labelledby="..."
, na tumutukoy sa modal na pamagat, sa .modal
, at role="document"
sa .modal-dialog
mismong. Bukod pa rito, maaari kang magbigay ng paglalarawan ng iyong modal dialog na may aria-describedby
sa .modal
.
Ang pag-embed ng mga video sa YouTube sa mga modal ay nangangailangan ng karagdagang JavaScript na wala sa Bootstrap upang awtomatikong ihinto ang pag-playback at higit pa. Tingnan ang kapaki-pakinabang na post na ito ng Stack Overflow para sa higit pang impormasyon.
Ang mga modal ay may dalawang opsyonal na laki, na magagamit sa pamamagitan ng mga klase ng modifier na ilalagay sa isang .modal-dialog
. Ang mga laki na ito ay nagsisimula sa ilang mga breakpoint upang maiwasan ang mga pahalang na scrollbar sa mas makitid na viewport.
I-toggle ng modal plugin ang iyong nakatagong content on demand, sa pamamagitan ng mga attribute ng data o JavaScript. Nagdaragdag din ito .modal-open
sa <body>
to override default na pag-scroll na gawi at bumubuo ng .modal-backdrop
para magbigay ng lugar ng pag-click para sa pag-dismiss ng mga ipinapakitang modal kapag nag-click sa labas ng modal.
Mag-activate ng modal nang hindi nagsusulat ng JavaScript. Itakda data-toggle="modal"
sa isang elemento ng controller, tulad ng isang button, kasama ng isang data-target="#foo"
o href="#foo"
upang i-target ang isang partikular na modal upang i-toggle.
Tumawag ng modal na may id myModal
na may isang linya ng JavaScript:
Maaaring ipasa ang mga opsyon sa pamamagitan ng mga katangian ng data o JavaScript. Para sa mga katangian ng data, idagdag ang pangalan ng opsyon sa data-
, tulad ng sa data-backdrop=""
.
Pangalan | Uri | Default | Paglalarawan |
---|---|---|---|
backdrop | boolean o ang string'static' |
totoo | May kasamang modal-backdrop na elemento. Bilang kahalili, tumukoy static para sa isang backdrop na hindi nagsasara ng modal sa pag-click. |
keyboard | boolean | totoo | Isinasara ang modal kapag pinindot ang escape key |
focus | boolean | totoo | Inilalagay ang focus sa modal kapag nasimulan. |
palabas | boolean | totoo | Ipinapakita ang modal kapag nasimulan. |
Mga asynchronous na pamamaraan at paglipat
Ang lahat ng mga pamamaraan ng API ay asynchronous at nagsisimula ng isang paglipat . Bumalik sila sa tumatawag sa sandaling magsimula ang paglipat ngunit bago ito matapos . Bilang karagdagan, babalewalain ang isang method call sa isang transitioning component .
Tingnan ang aming dokumentasyon ng JavaScript para sa higit pang impormasyon.
Ina-activate ang iyong content bilang modal. Tumatanggap ng opsyonal na opsyon object
.
Manu-manong i-toggle ang isang modal. Bumabalik sa tumatawag bago ang modal ay aktwal na naipakita o naitago (ibig sabihin, bago mangyari ang shown.bs.modal
o hidden.bs.modal
kaganapan).
Manu-manong nagbubukas ng modal. Bumabalik sa tumatawag bago aktwal na naipakita ang modal (ibig sabihin, bago shown.bs.modal
mangyari ang kaganapan).
Manu-manong nagtatago ng modal. Bumabalik sa tumatawag bago pa talaga naitago ang modal (ibig sabihin, bago hidden.bs.modal
mangyari ang kaganapan).
Manu-manong muling ayusin ang posisyon ng modal kung ang taas ng isang modal ay nagbabago habang ito ay bukas (ibig sabihin, kung sakaling lumitaw ang isang scrollbar).
Sinisira ang modal ng isang elemento.
Ang modal class ng Bootstrap ay naglalantad ng ilang mga kaganapan para sa hooking sa modal functionality. Ang lahat ng modal na kaganapan ay pinapagana sa modal mismo (ibig sabihin, sa <div class="modal">
).
Uri ng kaganapan | Paglalarawan |
---|---|
show.bs.modal | Agad na gagana ang kaganapang ito kapag show tinawag ang paraan ng instance. Kung sanhi ng isang pag-click, ang na-click na elemento ay magagamit bilang pag- relatedTarget aari ng kaganapan. |
ipinapakita.bs.modal | Ang kaganapang ito ay pinapagana kapag ang modal ay ginawang nakikita ng user (maghihintay na makumpleto ang mga transition ng CSS). Kung sanhi ng isang pag-click, ang na-click na elemento ay magagamit bilang pag- relatedTarget aari ng kaganapan. |
hide.bs.modal | Agad na pinapagana ang kaganapang ito kapag hide tinawag na ang paraan ng instance. |
hidden.bs.modal | Ang kaganapang ito ay papaganahin kapag ang modal ay tapos nang itago mula sa user (maghihintay na makumpleto ang mga transition ng CSS). |