in English

Поповери

Документација и примери за додавање Bootstrap popovers, како оние што се наоѓаат во iOS, на кој било елемент на вашата страница.

Преглед

Работи што треба да ги знаете кога го користите приклучокот за поповер:

  • Поповерите се потпираат на библиотеката од трета страна Popper за позиционирање. Мора да вклучите popper.min.js пред bootstrap.js или да користите bootstrap.bundle.min.js/ bootstrap.bundle.jsшто содржи Popper за да може поповерите да функционираат!
  • Поповерите бараат додаток за совети за алатки како зависност.
  • Ако го градите нашиот JavaScript од извор, тоа бараutil.js .
  • Поповерите се избираат поради перформанси, па мора сами да ги иницијализирате .
  • Нулта должина titleи contentвредности никогаш нема да покажат поповер.
  • Наведете container: 'body'за да избегнете рендерирање проблеми во посложени компоненти (како што се нашите влезни групи, групи копчиња итн.).
  • Активирањето поповери на скриените елементи нема да работи.
  • Поповер за .disabledили disabledелементи мора да се активираат на елементот за обвивка.
  • Кога ќе се активираат од сидра што се обвиткуваат преку повеќе линии, поповерите ќе бидат центрирани помеѓу вкупната ширина на сидрата. Користете .text-nowrapго вашиот <a>s за да го избегнете ова однесување.
  • Поповерите мора да се сокријат пред нивните соодветни елементи да бидат отстранети од DOM.
  • Поповерите може да се активираат благодарение на елемент во сенка DOM.
Стандардно, оваа компонента користи вградено средство за дезинфекција на содржината, кое ги отстранува сите елементи на HTML што не се експлицитно дозволени. Погледнете го делот за дезинфекција во нашата JavaScript документација за повеќе детали.
Ефектот на анимација на оваа компонента зависи од prefers-reduced-motionмедиумското барање. Погледнете го делот за намалено движење од нашата документација за пристапност .

Продолжете да читате за да видите како функционираат поповерите со некои примери.

Пример: овозможете popovers насекаде

Еден начин да се иницијализираат сите поповери на страницата би било да ги изберете според нивниот data-toggleатрибут:

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

Пример: Користење на containerопцијата

Кога имате некои стилови на родителски елемент што се мешаат со поповер, ќе сакате да наведете приспособување containerтака што HTML-от на поповерот да се појавува во тој елемент наместо тоа.

$(function () {
  $('.example-popover').popover({
    container: 'body'
  })
})

Пример

<button type="button" class="btn btn-lg btn-danger" data-toggle="popover" title="Popover title" data-content="And here's some amazing content. It's very engaging. Right?">Click to toggle popover</button>

Четири насоки

Достапни се четири опции: горе, десно, долу и лево порамнети.

<button type="button" class="btn btn-secondary" data-container="body" data-toggle="popover" data-placement="top" data-content="Top popover">
  Popover on top
</button>
<button type="button" class="btn btn-secondary" data-container="body" data-toggle="popover" data-placement="right" data-content="Right popover">
  Popover on right
</button>
<button type="button" class="btn btn-secondary" data-container="body" data-toggle="popover" data-placement="bottom" data-content="Bottom popover">
  Popover on bottom
</button>
<button type="button" class="btn btn-secondary" data-container="body" data-toggle="popover" data-placement="left" data-content="Left popover">
  Popover on left
</button>

Отфрли на следниот клик

Користете го focusактивирањето за да ги отфрлите поповерите при следното кликнување на корисникот на различен елемент од елементот за префрлување.

Потребна е специфична ознака за отфрлање-на-следниот-клик

За правилно однесување меѓу прелистувачите и меѓуплатформите, мора да ја користите <a>ознаката, а не<button> ознаката, а исто така мора да вклучите tabindexатрибут.

<a tabindex="0" class="btn btn-lg btn-danger" role="button" data-toggle="popover" data-trigger="focus" title="Dismissible popover" data-content="And here's some amazing content. It's very engaging. Right?">Dismissible popover</a>
$('.popover-dismiss').popover({
  trigger: 'focus'
})

Оневозможени елементи

Елементите со disabledатрибут не се интерактивни, што значи дека корисниците не можат да лебдат или да кликнат на нив за да активираат поповер (или совет за алатка). Како заобиколување, ќе сакате да го активирате поповерот од обвивка <div>или <span>и да го отфрлите pointer-eventsоневозможениот елемент.

За оневозможени предизвикувачи на поповер, исто така може да претпочитате data-trigger="hover"пукањето да се појавува како непосредна визуелна повратна информација за вашите корисници бидејќи тие можеби не очекуваат да кликнат на оневозможен елемент.

<span class="d-inline-block" data-toggle="popover" data-content="Disabled popover">
  <button class="btn btn-primary" style="pointer-events: none;" type="button" disabled>Disabled button</button>
</span>

Употреба

Овозможете popovers преку JavaScript:

$('#example').popover(options)
Забрзување на графичкиот процесор

Поповерите понекогаш се појавуваат нејасни на уредите со Windows 10 поради забрзувањето на графичкиот процесор и модифицираниот системски DPI. Решението за ова во v4 е да се оневозможи забрзувањето на графичкиот процесор колку што е потребно на вашите поповери.

Предложено решение:

Popper.Defaults.modifiers.computeStyle.gpuAcceleration = !(window.devicePixelRatio < 1.5 && /Win/.test(navigator.platform))

Да се ​​направат поповерите да работат за корисници на тастатура и помошна технологија

За да им дозволите на корисниците на тастатурата да ги активираат вашите поповери, треба да ги додавате само во HTML елементи кои традиционално се фокусирани на тастатурата и интерактивни (како што се врски или контроли на форма). Иако произволните HTML-елементи (како што се <span>s) може да се направат фокусирани со додавање на tabindex="0"атрибутот, ова ќе додаде потенцијално досадни и збунувачки таб-стопови на неинтерактивни елементи за корисниците на тастатурата, а повеќето помошни технологии моментално не ја објавуваат содржината на поповер во оваа ситуација . Дополнително, немојте да се потпирате само на hoverкако активирач за вашите поповери, бидејќи тоа ќе го оневозможи нивното активирање за корисниците на тастатура.

Иако можете да вметнете богат, структуриран HTML во поповери со htmlопцијата, ние силно препорачуваме да избегнувате да додавате прекумерна количина на содржина. Начинот на кој поповерите моментално функционираат е тоа што, откако ќе се прикажат, нивната содржина е врзана за активирачкиот елемент со aria-describedbyатрибутот. Како резултат на тоа, целата содржина на поповер ќе им биде објавена на корисниците на помошната технологија како еден долг, непрекинат пренос.

Дополнително, иако е можно да вклучите и интерактивни контроли (како што се елементи на форма или врски) во вашиот popover (со додавање на овие елементи на whiteListили дозволените атрибути и ознаки), имајте предвид дека моментално popover-от не управува со редоследот на фокусирање на тастатурата. Кога корисникот на тастатурата отвора поповер, фокусот останува на активирачкиот елемент и бидејќи пукањето обично не го следи веднаш активирањето во структурата на документот, нема гаранција дека се движи напред/притискаTABќе премести корисник на тастатура во самиот поповер. Накратко, едноставното додавање на интерактивни контроли на поповер веројатно ќе ги направи овие контроли недостапни/неупотребливи за корисниците на тастатура и корисниците на помошни технологии, или во најмала рака ќе направи нелогичен целокупен редослед на фокусирање. Во овие случаи, размислете наместо тоа да користите модален дијалог.

Опции

Опциите може да се пренесат преку атрибути на податоци или JavaScript. За атрибути на податоци, додајте го името на опцијата на data-, како во data-animation="".

Забележете дека од безбедносни причини опциите sanitize, sanitizeFnи whiteListне може да се обезбедат со користење на атрибути на податоци.
Име Тип Стандардно Опис
анимација булови вистина Примени CSS Fade транзиција на поповер
контејнер низа | елемент | лажни лажни

Го додава поповерот на одреден елемент. Пример: container: 'body'. Оваа опција е особено корисна со тоа што ви овозможува да го поставите поповерот во текот на документот во близина на елементот за активирање - што ќе спречи скокачот да лебди подалеку од елементот за активирање при промена на големината на прозорецот.

содржина низа | елемент | функција ''

Стандардна вредност на содржината ако data-contentатрибутот не е присутен.

Ако е дадена функција, таа ќе се повика со нејзиното thisреферентно множество до елементот на кој е прикачен поповерот.

одложување број | објект 0

Одложено прикажување и сокривање на поповер (ms) - не важи за рачниот тип на активирач

Ако е доставен број, доцнењето се применува и за сокривање/прикажување

Структурата на објектот е:delay: { "show": 500, "hide": 100 }

html булови лажни Вметнете HTML во поповерот. Ако е неточно, textметодот на jQuery ќе се користи за вметнување содржина во DOM. Користете текст ако сте загрижени за нападите на XSS.
поставување низа | функција 'право'

Како да се позиционира поповер - авто | врвот | дното | лево | право.
Кога autoе одредено, тој динамично ќе го преориентира поповерот.

Кога функцијата се користи за определување на поставеноста, таа се повикува со јазолот DOM поповер како прв аргумент и активирачкиот елемент DOM јазол како негов втор. Контекстот thisе поставен на инстанцата поповер.

селектор низа | лажни лажни Ако е обезбеден селектор, објектите за поповер ќе бидат делегирани на наведените цели. Во пракса, ова се користи за да се овозможи динамична HTML содржина да има додадени поповери. Видете го ова и информативен пример .
шаблон низа '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>'

Основен HTML што треба да се користи при креирање на поповер.

Поповерот titleќе се инјектира во .popover-header.

Поповерот contentќе се инјектира во .popover-body.

.arrowќе стане стрела на поповерот.

Најоддалечениот елемент за обвивка треба да ја има .popoverкласата.

Наслов низа | елемент | функција ''

Стандардна вредност на насловот ако titleатрибутот не е присутен.

Ако е дадена функција, таа ќе се повика со нејзиното thisреферентно множество до елементот на кој е прикачен поповерот.

чкрапало низа 'кликни' Како се активира поповер - кликнете | лебди | фокус | прирачник. Може да поминете повеќе предизвикувачи; одделете ги со празно место. manualне може да се комбинира со кој било друг активирач.
офсет број | низа 0 Поместување на поповер во однос на неговата цел. За повеќе информации погледнете ги офсет документите на Попер .
резервна поставеност низа | низа 'превртување' Дозволете да одредите која позиција ќе ја користи Попер при резервна копија. За повеќе информации погледнете ги документите за однесувањето на Попер
прилагодена класа низа | функција ''

Додајте класи на поповер кога ќе се прикаже. Имајте предвид дека овие класи ќе се додадат како додаток на класите наведени во шаблонот. За да додадете повеќе класи, одделете ги со празни места: 'a b'.

Можете исто така да пренесете функција која треба да врати една низа што содржи дополнителни имиња на класи.

граница низа | елемент 'scrollParent' Границата на ограничување на прелевање на поповер. Ги прифаќа вредностите на 'viewport', 'window', 'scrollParent'или референца на HTMLElement (само JavaScript). За повеќе информации, погледнете ги Popper's preventOverflow docs .
дезинфицираат булови вистина Овозможете или оневозможете ја дезинфекцијата. Ако се активира 'template', 'content'и 'title'опциите ќе се дезинфицираат. Погледнете го делот за дезинфекција во нашата JavaScript документација .
бела листа објект Стандардна вредност Објект кој содржи дозволени атрибути и ознаки
sanitizeFn нула | функција нула Овде можете да обезбедите своја сопствена функција за дезинфекција. Ова може да биде корисно ако претпочитате да користите посебна библиотека за да извршите дезинфекција.
popperConfig нула | објект нула За да ја промените стандардната Popper конфигурација на Bootstrap, видете ја конфигурацијата на Popper

Атрибути на податоци за поединечни поповери

Опциите за поединечни поповери може алтернативно да се специфицираат преку употреба на атрибути на податоци, како што е објаснето погоре.

Методи

Асинхрони методи и транзиции

Сите API методи се асинхрони и започнуваат транзиција . Тие се враќаат кај повикувачот штом ќе започне транзицијата, но пред да заврши . Дополнително, повик на метод на компонента во транзиција ќе се игнорира .

Погледнете ја нашата JavaScript документација за повеќе информации .

$().popover(options)

Иницијализира поповери за колекција на елементи.

.popover('show')

Открива популарност на елементот. Се враќа кај повикувачот пред да се прикаже поповерот (т.е. пред да се shown.bs.popoverслучи настанот). Ова се смета за „рачно“ активирање на поповер. Поповерите чиј наслов и содржина се со нулта должина никогаш не се прикажуваат.

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

.popover('hide')

Го крие поповерот на елементот. Се враќа на повикувачот пред да се сокрие поповерот (т.е. пред да се hidden.bs.popoverслучи настанот). Ова се смета за „рачно“ активирање на поповер.

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

.popover('toggle')

Вклучува исклучување на елементот. Се враќа на повикувачот пред да се прикаже или скрие пукачот (т.е. пред да се случи настанот shown.bs.popoverили hidden.bs.popoverнастанот). Ова се смета за „рачно“ активирање на поповер.

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

.popover('dispose')

Сокрива и уништува поповер на елементот. Поповерите што користат делегирање (кои се креирани со опцијата selector) не можат да се уништат поединечно на елементите за потомство.

$('#element').popover('dispose')

.popover('enable')

Дава можност за прикажување на popover на елементот. Поповерите се стандардно овозможени.

$('#element').popover('enable')

.popover('disable')

Ја отстранува можноста за прикажување на popover на елементот. Поповерот ќе може да се прикаже само ако е повторно овозможен.

$('#element').popover('disable')

.popover('toggleEnabled')

Ја исклучува можноста за прикажување или сокривање на popover на елементот.

$('#element').popover('toggleEnabled')

.popover('update')

Ја ажурира позицијата на поповер на елементот.

$('#element').popover('update')

Настани

Тип на настан Опис
шоу.бс.поповер Овој настан се вклучува веднаш кога showќе се повика методот на пример.
прикажани.бс.поповер Овој настан се активира кога поповерот е видлив за корисникот (ќе чека да се завршат транзициите на CSS).
скриј.бс.поповер Овој настан се активира веднаш кога hideќе се повика методот на пример.
скриени.бс.поповер Овој настан се активира кога поповерот ќе заврши со криење од корисникот (ќе почека да се завршат транзициите на CSS).
вметната.бс.поповер Овој настан се активира по show.bs.popoverнастанот кога шаблонот за поповер е додаден во DOM.
$('#myPopover').on('hidden.bs.popover', function () {
  // do something...
})