Modal
Tumia programu-jalizi ya modali ya JavaScript ya Bootstrap ili kuongeza vidadisi kwenye tovuti yako kwa visanduku vyepesi, arifa za watumiaji, au maudhui maalum kabisa.
Inavyofanya kazi
Kabla ya kuanza na kijenzi cha modali cha Bootstrap, hakikisha kuwa umesoma yafuatayo kwani chaguzi zetu za menyu zimebadilika hivi majuzi.
- Moduli hujengwa kwa HTML, CSS na JavaScript. Zimewekwa juu ya kila kitu kingine kwenye hati na huondoa kusongesha kutoka
<body>
ili maudhui ya modal yasogeze badala yake. - Kubofya kwenye "mandhari" ya modal kutafunga modali kiotomatiki.
- Bootstrap inasaidia tu dirisha moja la modal kwa wakati mmoja. Miundo iliyopachikwa haitumiki kwa kuwa tunaamini kuwa matumizi mabaya ya watumiaji.
- Modals use
position: fixed
, ambayo wakati mwingine inaweza kuwa maalum kidogo juu ya utoaji wake. Inapowezekana, weka HTML yako ya modali katika nafasi ya juu ili kuepuka kuingiliwa kwa vipengele vingine. Huenda utakumbana na matatizo wakati wa kuweka kiota.modal
ndani ya kipengele kingine kisichobadilika. - Kwa mara nyingine tena, kutokana na
position: fixed
, kuna baadhi ya tahadhari za kutumia moduli kwenye vifaa vya rununu. Tazama hati zetu za usaidizi wa kivinjari kwa maelezo. - Kutokana na jinsi HTML5 inavyofafanua semantiki zake, sifa ya
autofocus
HTML haina athari katika miundo ya Bootstrap. Ili kufikia athari sawa, tumia JavaScript maalum:
$('#myModal').on('shown.bs.modal', function () {
$('#myInput').trigger('focus')
})
prefers-reduced-motion
hoja ya midia. Tazama
sehemu ya mwendo iliyopunguzwa ya hati zetu za ufikivu .
Endelea kusoma kwa maonyesho na miongozo ya matumizi.
Mifano
Vipengele vya modal
Chini ni mfano tuli wa modal (ikimaanisha kuwa yake position
na display
imebatilishwa). Imejumuishwa ni kichwa cha modali, mwili wa modali (inahitajika kwa padding
), na kijachini cha modali (si lazima). Tunaomba ujumuishe vichwa vya modal na vitendo vya kuondoa kila inapowezekana, au utoe hatua nyingine ya wazi ya kukataa.
<div class="modal" tabindex="-1">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title">Modal title</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body">
<p>Modal body text goes here.</p>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary">Save changes</button>
</div>
</div>
</div>
</div>
Onyesho la moja kwa moja
Geuza onyesho la modali ya kufanya kazi kwa kubofya kitufe kilicho hapa chini. Itateleza chini na kufifia kutoka juu ya ukurasa.
<!-- Button trigger modal -->
<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#exampleModal">
Launch demo modal
</button>
<!-- Modal -->
<div class="modal fade" id="exampleModal" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Modal title</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body">
...
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary">Save changes</button>
</div>
</div>
</div>
</div>
Mandhari tuli
Mandhari ya nyuma yanapowekwa kuwa tuli, modali haitafungwa wakati wa kubofya nje yake. Bofya kitufe kilicho hapa chini ili kuijaribu.
<!-- Button trigger modal -->
<button type="button" class="btn btn-primary" data-toggle="modal" data-target="#staticBackdrop">
Launch static backdrop modal
</button>
<!-- Modal -->
<div class="modal fade" id="staticBackdrop" data-backdrop="static" data-keyboard="false" tabindex="-1" aria-labelledby="staticBackdropLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="staticBackdropLabel">Modal title</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body">
...
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary">Understood</button>
</div>
</div>
</div>
</div>
Inasogeza maudhui marefu
Miundo inapokua ndefu sana kwa kituo cha kutazama au kifaa cha mtumiaji, husogeza bila ya ukurasa wenyewe. Jaribu onyesho hapa chini ili kuona tunamaanisha nini.
Unaweza pia kuunda moduli inayoweza kusongeshwa ambayo inaruhusu kusogeza mwili wa modali kwa kuongeza .modal-dialog-scrollable
kwa .modal-dialog
.
<!-- Scrollable modal -->
<div class="modal-dialog modal-dialog-scrollable">
...
</div>
Imewekwa katikati
Ongeza .modal-dialog-centered
kwa .modal-dialog
katikati wima katikati ya modali.
<!-- Vertically centered modal -->
<div class="modal-dialog modal-dialog-centered">
...
</div>
<!-- Vertically centered scrollable modal -->
<div class="modal-dialog modal-dialog-centered modal-dialog-scrollable">
...
</div>
Vidokezo vya zana na popover
Vidokezo vya zana na popover vinaweza kuwekwa ndani ya moduli kama inahitajika. Wakati moduli zimefungwa, vidokezo vyovyote vya zana na popover ndani pia huondolewa kiotomatiki.
<div class="modal-body">
<h5>Popover in a modal</h5>
<p>This <a href="#" role="button" class="btn btn-secondary popover-test" title="Popover title" data-content="Popover body content is set in this attribute.">button</a> triggers a popover on click.</p>
<hr>
<h5>Tooltips in a modal</h5>
<p><a href="#" class="tooltip-test" title="Tooltip">This link</a> and <a href="#" class="tooltip-test" title="Tooltip">that link</a> have tooltips on hover.</p>
</div>
Kutumia gridi ya taifa
Tumia mfumo wa gridi ya Bootstrap ndani ya modali kwa kuweka kiota .container-fluid
ndani ya .modal-body
. Kisha, tumia madarasa ya mfumo wa gridi ya kawaida kama ungefanya mahali pengine popote.
<div class="modal-body">
<div class="container-fluid">
<div class="row">
<div class="col-md-4">.col-md-4</div>
<div class="col-md-4 ml-auto">.col-md-4 .ml-auto</div>
</div>
<div class="row">
<div class="col-md-3 ml-auto">.col-md-3 .ml-auto</div>
<div class="col-md-2 ml-auto">.col-md-2 .ml-auto</div>
</div>
<div class="row">
<div class="col-md-6 ml-auto">.col-md-6 .ml-auto</div>
</div>
<div class="row">
<div class="col-sm-9">
Level 1: .col-sm-9
<div class="row">
<div class="col-8 col-sm-6">
Level 2: .col-8 .col-sm-6
</div>
<div class="col-4 col-sm-6">
Level 2: .col-4 .col-sm-6
</div>
</div>
</div>
</div>
</div>
</div>
Kutofautisha maudhui ya modal
Una rundo la vitufe ambavyo vyote huanzisha modali sawa na yaliyomo tofauti kidogo? Tumia event.relatedTarget
na sifa za HTMLdata-*
(labda kupitia jQuery ) ili kubadilisha yaliyomo kwenye modali kulingana na kitufe kilichobofya.
Ifuatayo ni onyesho la moja kwa moja linalofuatwa na mfano wa HTML na JavaScript. Kwa habari zaidi, soma hati za matukio ya modal kwa maelezo kuhusu 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" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<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>
$('#exampleModal').on('show.bs.modal', function (event) {
var button = $(event.relatedTarget) // Button that triggered the modal
var recipient = button.data('whatever') // Extract info from data-* attributes
// If necessary, you could initiate an AJAX request here (and then do the updating in a callback).
// Update the modal's content. We'll use jQuery here, but you could use a data binding library or other methods instead.
var modal = $(this)
modal.find('.modal-title').text('New message to ' + recipient)
modal.find('.modal-body input').val(recipient)
})
Badilisha uhuishaji
Tofauti $modal-fade-transform
huamua hali ya mageuzi ya .modal-dialog
kabla ya uhuishaji wa modali kufifia, $modal-show-transform
kigezo huamua ubadilishaji wa .modal-dialog
mwisho wa uhuishaji wa modal fade-in.
Ikiwa unataka kwa mfano uhuishaji wa kukuza, unaweza kuweka $modal-fade-transform: scale(.8)
.
Ondoa uhuishaji
Kwa moduli zinazoonekana tu badala ya kufifia ili kutazamwa, ondoa .fade
darasa kutoka kwa alama yako ya modal.
<div class="modal" tabindex="-1" aria-labelledby="..." aria-hidden="true">
...
</div>
Urefu wenye nguvu
Ikiwa urefu wa modali hubadilika wakati umefunguliwa, unapaswa kupiga simu $('#myModal').modal('handleUpdate')
ili kurekebisha nafasi ya modali ikiwa upau wa kusogeza utatokea.
Ufikivu
Hakikisha umeongeza aria-labelledby="..."
, ukirejelea kichwa cha modali, kwa .modal
. Zaidi ya hayo, unaweza kutoa maelezo ya kidadisi chako cha modal na aria-describedby
on .modal
. Kumbuka kwamba huhitaji kuongeza role="dialog"
kwa kuwa tayari tunaiongeza kupitia JavaScript.
Inapachika video za YouTube
Kupachika video za YouTube katika miundo kunahitaji JavaScript ya ziada si kwenye Bootstrap ili kusimamisha uchezaji kiotomatiki na zaidi. Tazama chapisho hili muhimu la Stack Overflow kwa maelezo zaidi.
Ukubwa wa hiari
Moduli zina saizi tatu za hiari, zinapatikana kupitia madarasa ya kurekebisha kuwekwa kwenye .modal-dialog
. Saizi hizi huingia katika sehemu fulani za kukatika ili kuepuka pau za kusogeza zilizo mlalo kwenye lango finyu za kutazama.
Ukubwa | Darasa | Modal max-upana |
---|---|---|
Ndogo | .modal-sm |
300px |
Chaguomsingi | Hakuna | 500px |
Kubwa | .modal-lg |
800px |
Ziada kubwa | .modal-xl |
1140px |
Modali yetu chaguo-msingi bila darasa la kirekebishaji inajumuisha modali ya ukubwa wa "wastani".
<div class="modal-dialog modal-xl">...</div>
<div class="modal-dialog modal-lg">...</div>
<div class="modal-dialog modal-sm">...</div>
Matumizi
Programu-jalizi ya modal hugeuza maudhui yako yaliyofichwa inapohitajika, kupitia sifa za data au JavaScript. Pia huongeza .modal-open
kwa <body>
kubatilisha tabia ya kusogeza chaguo-msingi na hutoa a .modal-backdrop
kutoa eneo la kubofya kwa ajili ya kuondoa miundo iliyoonyeshwa unapobofya nje ya modali.
Kupitia sifa za data
Washa modali bila kuandika JavaScript. Weka data-toggle="modal"
kwenye kipengele cha kidhibiti, kama kitufe, pamoja na data-target="#foo"
au href="#foo"
kulenga modi mahususi ya kugeuza.
<button type="button" data-toggle="modal" data-target="#myModal">Launch modal</button>
Kupitia JavaScript
Piga modali na kitambulisho myModal
na safu moja ya JavaScript:
$('#myModal').modal(options)
Chaguo
Chaguzi zinaweza kupitishwa kupitia sifa za data au JavaScript. Kwa sifa za data, ongeza jina la chaguo kwa data-
, kama katika data-backdrop=""
.
Jina | Aina | Chaguomsingi | Maelezo |
---|---|---|---|
mandhari | boolean au kamba'static' |
kweli | Inajumuisha kipengele cha mandharinyuma ya modal. Vinginevyo, bainisha static kwa mandhari ambayo haifungi muundo wa kubofya. |
kibodi | boolean | kweli | Hufunga modali wakati kitufe cha Escape kinapobozwa |
kuzingatia | boolean | kweli | Huweka mkazo kwenye modali inapoanzishwa. |
onyesha | boolean | kweli | Inaonyesha moduli inapoanzishwa. |
Mbinu
Njia za Asynchronous na mabadiliko
Njia zote za API ni za asynchronous na zinaanzisha mpito . Wanarudi kwa mpigaji mara tu mpito unapoanza lakini kabla haujaisha . Kwa kuongeza, simu ya mbinu kwenye sehemu ya mpito itapuuzwa .
.modal(options)
Huwasha maudhui yako kama modali. Inakubali chaguo za hiari object
.
$('#myModal').modal({
keyboard: false
})
.modal('toggle')
Hugeuza modali mwenyewe. Hurejesha kwa mpigaji simu kabla modali haijaonyeshwa au kufichwa (yaani kabla ya tukio shown.bs.modal
au hidden.bs.modal
tukio).
$('#myModal').modal('toggle')
.modal('show')
Hufungua modali mwenyewe. Hurejesha kwa mpigaji simu kabla modali haijaonyeshwa (yaani kabla ya shown.bs.modal
tukio kutokea).
$('#myModal').modal('show')
.modal('hide')
Huficha modali mwenyewe. Hurejesha kwa mpigaji simu kabla modali haijafichwa (yaani kabla ya hidden.bs.modal
tukio kutokea).
$('#myModal').modal('hide')
.modal('handleUpdate')
Rekebisha mwenyewe nafasi ya modali ikiwa urefu wa modali hubadilika wakati iko wazi (yaani ikiwa upau wa kusogeza utatokea).
$('#myModal').modal('handleUpdate')
.modal('dispose')
Huharibu modi ya kipengele.
Matukio
Darasa la modali la Bootstrap linafichua matukio machache ya kuunganisha kwenye utendakazi wa modal. Matukio yote ya modal yanarushwa kwa modali yenyewe (yaani kwenye <div class="modal">
).
Aina ya Tukio | Maelezo |
---|---|
onyesha.bs.modal | Tukio hili huwaka mara moja wakati show njia ya mfano inaitwa. Ikisababishwa na kubofya, kipengele kilichobofya kinapatikana kama sifa relatedTarget ya tukio. |
mfano.bs.ulioonyeshwa | Tukio hili linafutwa wakati modali imefanywa kuonekana kwa mtumiaji (itasubiri mabadiliko ya CSS kukamilika). Ikisababishwa na kubofya, kipengele kilichobofya kinapatikana kama sifa relatedTarget ya tukio. |
ficha.bs.modal | Tukio hili linafutwa mara moja wakati hide njia ya mfano imeitwa. |
fiche.bs.modal | Tukio hili litafutwa wakati modali imekamilika kufichwa kutoka kwa mtumiaji (itasubiri mabadiliko ya CSS kukamilika). |
FichaImezuiwa.b.modali | Tukio hili hutupwa wakati modali inaonyeshwa, mandhari yake ni static na kubofya nje ya modali au ubonyezo wa kitufe cha kutoroka hufanywa kwa chaguo la kibodi au data-keyboard kuweka false . |
$('#myModal').on('hidden.bs.modal', function (event) {
// do something...
})