Модален
Користете го модалниот приклучок за JavaScript на Bootstrap за да додадете дијалози на вашата страница за светлосни кутии, кориснички известувања или целосно приспособена содржина.
Како работи
Пред да започнете со модалната компонента на Bootstrap, задолжително прочитајте го следново бидејќи нашите опции од менито неодамна се сменија.
- Модалите се изградени со HTML, CSS и JavaScript. Тие се позиционирани над сè друго во документот и го отстрануваат лизгањето од,
<body>
така што модалната содржина се лизга наместо тоа. - Со кликнување на модалната „заднина“ автоматски ќе се затвори модалот.
- Bootstrap поддржува само еден модален прозорец во исто време. Вгнездените модали не се поддржани бидејќи веруваме дека се лоши кориснички искуства.
- Модалите користат
position: fixed
, што понекогаш може да биде малку особено за неговото прикажување. Секогаш кога е можно, поставете го вашиот модален HTML во позиција на највисоко ниво за да избегнете потенцијални пречки од други елементи. Веројатно ќе наидете на проблеми кога вгнездувате.modal
во друг фиксен елемент. - Уште еднаш, поради
position: fixed
, има некои предупредувања за користење модали на мобилни уреди. Видете ги нашите документи за поддршка на прелистувачот за детали. - Поради тоа како HTML5 ја дефинира својата семантика, атрибутот
autofocus
HTML нема ефект во модалите на Bootstrap. За да го постигнете истиот ефект, користете некој прилагоден JavaScript:
$('#myModal').on('shown.bs.modal', function () {
$('#myInput').trigger('focus')
})
prefers-reduced-motion
медиумското барање. Погледнете го делот за
намалено движење од нашата документација за пристапност .
Продолжете да читате за демо снимки и упатства за користење.
Примери
Модални компоненти
Подолу е статичен модален пример (што значи дека има position
и display
е отфрлено). Вклучени се модалното заглавие, модалното тело (потребно за padding
) и модалното подножје (опционално). Ве молиме да вклучите модални заглавија со дејства за отфрлање секогаш кога е можно или да обезбедите друго експлицитно дејство за отфрлање.
<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>
Демо во живо
Вклучете работна модална демонстрација со кликнување на копчето подолу. Ќе се лизне надолу и ќе избледи од врвот на страницата.
<!-- 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>
Статична позадина
Кога заднината е поставена на статична, модалот нема да се затвори при кликнување надвор од неа. Кликнете на копчето подолу за да го пробате.
<!-- 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>
Скролање долга содржина
Кога модалите стануваат премногу долги за приказот или уредот на корисникот, тие се движат независно од самата страница. Пробајте го демото подолу за да видите на што мислиме.
Можете исто така да креирате модал кој може да се движи што овозможува лизгање на модалното тело со додавање .modal-dialog-scrollable
на .modal-dialog
.
<!-- Scrollable modal -->
<div class="modal-dialog modal-dialog-scrollable">
...
</div>
Вертикално центриран
Додај .modal-dialog-centered
во .modal-dialog
за вертикално центрирање на модалот.
<!-- 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>
Совети за алатки и поповери
По потреба може да се постават совети за алатки и поповер во модали. Кога модалите се затворени, сите совети за алатки и поповери внатре исто така автоматски се отфрлаат.
<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>
Користење на решетката
Користете го Bootstrap грид системот во модал со вгнездување .container-fluid
во .modal-body
. Потоа, користете ги нормалните класи на мрежни системи како на кое било друго место.
<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>
Различна модална содржина
Дали имате еден куп копчиња што го активираат истиот модал со малку поинаква содржина? Користете event.relatedTarget
и HTML data-*
атрибути (можеби преку jQuery ) за да ја менувате содржината на модалот во зависност од тоа на кое копче е кликнато.
Подолу е демо во живо проследено со пример HTML и JavaScript. За повеќе информации, прочитајте ги документите за модални настани за детали за 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)
})
Променете ја анимацијата
Променливата $modal-fade-transform
ја одредува состојбата на трансформација на .modal-dialog
пред модалната анимација за избледување, $modal-show-transform
променливата ја одредува трансформацијата на .modal-dialog
на крајот од модалната анимација за избледување.
Ако сакате, на пример, анимација за зумирање, можете да поставите $modal-fade-transform: scale(.8)
.
Отстранете ја анимацијата
За модали кои едноставно се појавуваат наместо да бледнеат за да ги видите, отстранете ја .fade
класата од вашата модална ознака.
<div class="modal" tabindex="-1" aria-labelledby="..." aria-hidden="true">
...
</div>
Динамични висини
Ако висината на модалот се промени додека е отворен, треба да повикате $('#myModal').modal('handleUpdate')
за повторно да ја прилагодите позицијата на модалот во случај да се појави лента за лизгање.
Пристапност
Не заборавајте да додадете aria-labelledby="..."
, повикувајќи се на модалниот наслов, на .modal
. Дополнително, можете да дадете опис на вашиот модален дијалог со aria-describedby
на .modal
. Имајте предвид дека не треба да додавате role="dialog"
бидејќи ние веќе го додаваме преку JavaScript.
Вградување видеа на YouTube
Вградувањето видеа на YouTube во модали бара дополнителен JavaScript не во Bootstrap за автоматско запирање на репродукцијата и многу повеќе. Погледнете ја оваа корисна објава на Stack Overflow за повеќе информации.
Изборни големини
Модалите имаат три изборни големини, достапни преку класите на модификатори за да се постават на .modal-dialog
. Овие големини влегуваат во одредени точки на прекин за да се избегнат хоризонталните ленти за лизгање на потесни пристаништа за гледање.
Големина | Класа | Модална максимална ширина |
---|---|---|
Мали | .modal-sm |
300px |
Стандардно | Никој | 500px |
Големи | .modal-lg |
800px |
Многу голем | .modal-xl |
1140px |
Нашиот стандарден модал без класа на модификатор го сочинува модалот со „средна“ големина.
<div class="modal-dialog modal-xl">...</div>
<div class="modal-dialog modal-lg">...</div>
<div class="modal-dialog modal-sm">...</div>
Употреба
Модалниот приклучок ја менува вашата скриена содржина на барање, преку атрибути на податоци или JavaScript. Тој, исто така, додава .modal-open
на <body>
замена за стандардното однесување на лизгање и генерира a .modal-backdrop
за да обезбеди област за кликнување за отфрлање на прикажаните модали кога се кликнува надвор од модалот.
Преку атрибути на податоци
Активирајте модал без да пишувате JavaScript. Поставете data-toggle="modal"
на елемент на контролорот, како копче, заедно со data-target="#foo"
или href="#foo"
за да насочите конкретен модал за префрлување.
<button type="button" data-toggle="modal" data-target="#myModal">Launch modal</button>
Преку JavaScript
Повикајте модал со id myModal
со една линија JavaScript:
$('#myModal').modal(options)
Опции
Опциите може да се пренесат преку атрибути на податоци или JavaScript. За атрибути на податоци, додајте го името на опцијата на data-
, како во data-backdrop=""
.
Име | Тип | Стандардно | Опис |
---|---|---|---|
позадина | бул или стрингот'static' |
вистина | Вклучува елемент на модална заднина. Алтернативно, наведете static заднина која не го затвора модалот при кликнување. |
тастатура | булови | вистина | Го затвора модалот кога ќе се притисне копчето за бегство |
фокус | булови | вистина | Го става фокусот на модалот кога се иницијализира. |
покажуваат | булови | вистина | Го прикажува модалот кога е иницијализиран. |
Методи
Асинхрони методи и транзиции
Сите API методи се асинхрони и започнуваат транзиција . Тие се враќаат кај повикувачот штом ќе започне транзицијата, но пред да заврши . Дополнително, повик на метод на компонента во транзиција ќе се игнорира .
Погледнете ја нашата JavaScript документација за повеќе информации .
.modal(options)
Ја активира вашата содржина како модална. Прифаќа изборни опции object
.
$('#myModal').modal({
keyboard: false
})
.modal('toggle')
Рачно менува модал. Се враќа кај повикувачот пред модалот навистина да биде прикажан или скриен (т.е. пред да се случи настанот shown.bs.modal
или hidden.bs.modal
).
$('#myModal').modal('toggle')
.modal('show')
Рачно отвора модал. Се враќа кај повикувачот пред всушност да се прикаже модалот (т.е. пред да се shown.bs.modal
случи настанот).
$('#myModal').modal('show')
.modal('hide')
Рачно крие модал. Се враќа на повикувачот пред всушност да се скрие модалот (т.е. пред да се hidden.bs.modal
случи настанот).
$('#myModal').modal('hide')
.modal('handleUpdate')
Рачно приспособете ја позицијата на модалот ако висината на модалот се промени додека е отворен (т.е. во случај да се појави лента за лизгање).
$('#myModal').modal('handleUpdate')
.modal('dispose')
Уништува модал на елемент.
Настани
Модалната класа на Bootstrap изложува неколку настани за закачување во модалната функционалност. Сите модални настани се активираат на самиот модал (т.е. во <div class="modal">
).
Тип на настан | Опис |
---|---|
покажуваат.бс.модална | Овој настан се вклучува веднаш кога show ќе се повика методот на пример. Ако е предизвикано од кликнување, кликнатиот елемент е достапен како relatedTarget својство на настанот. |
прикажани.бс.модални | Овој настан се активира кога модалот е видлив за корисникот (ќе чека да се завршат транзициите на CSS). Ако е предизвикано од кликнување, кликнатиот елемент е достапен како relatedTarget својство на настанот. |
скриј.бс.модален | Овој настан се активира веднаш кога hide ќе се повика методот на пример. |
скриени.бс.модални | Овој настан се активира кога модалот ќе заврши со криење од корисникот (ќе почека да се завршат транзициите на CSS). |
крие Спречено.бс.модален | Овој настан се активира кога модалот е прикажан, неговата заднина е static и се врши кликнување надвор од модалот или притискање на копче за бегство со опцијата за тастатура или data-keyboard поставено на false . |
$('#myModal').on('hidden.bs.modal', function (event) {
// do something...
})