JavaScript
Sasisha Bootstrap na programu-jalizi zetu za hiari za JavaScript zilizojengwa kwenye jQuery. Jifunze kuhusu kila programu-jalizi, data na chaguo zetu za API za kiprogramu, na zaidi.
Ya mtu binafsi au iliyokusanywa
Programu-jalizi zinaweza kujumuishwa kibinafsi (kwa kutumia Bootstrap ya mtu binafsi js/dist/*.js
), au zote kwa wakati mmoja kwa kutumia bootstrap.js
au minified bootstrap.min.js
(usijumuishe zote mbili).
Ukitumia kifurushi (Webpack, Rollup...), unaweza kutumia /js/dist/*.js
faili ambazo UMD tayari.
Vitegemezi
Baadhi ya programu-jalizi na vipengele vya CSS hutegemea programu-jalizi zingine. Ikiwa utajumuisha programu-jalizi kibinafsi, hakikisha kuwa umeangalia tegemezi hizi kwenye hati. Pia kumbuka kuwa programu- jalizi zote hutegemea jQuery (hii inamaanisha jQuery lazima ijumuishwe kabla ya faili za programu-jalizi). Wasiliana nasipackage.json
ili kuona ni matoleo gani ya jQuery yanatumika.
Kunjuzi zetu, popover na vidokezo vya zana pia hutegemea Popper.js .
Sifa za data
Takriban programu-jalizi zote za Bootstrap zinaweza kuwashwa na kusanidiwa kupitia HTML pekee na sifa za data (njia tunayopendelea ya kutumia utendaji wa JavaScript). Hakikisha kuwa unatumia seti moja tu ya sifa za data kwenye kipengele kimoja (kwa mfano, huwezi kuanzisha kidokezo na modali kutoka kwa kitufe kimoja.)
Walakini, katika hali zingine inaweza kuhitajika kuzima utendakazi huu. Ili kuzima API ya sifa ya data, tenganisha matukio yote kwenye hati iliyo na nafasi data-api
kama vile:
$(document).off('.data-api')
Vinginevyo, ili kulenga programu-jalizi maalum, jumuisha tu jina la programu-jalizi kama nafasi ya majina pamoja na nafasi ya majina ya data-api kama hii:
$(document).off('.alert.data-api')
Wateuzi
Kwa sasa ili kuuliza vipengele vya DOM tunatumia mbinu asilia querySelector
na querySelectorAll
kwa sababu za utendaji, kwa hivyo ni lazima utumie viteuzi halali . Ikiwa unatumia viteuzi maalum, kwa mfano: collapse:Example
hakikisha kuwatoroka.
Matukio
Bootstrap hutoa matukio maalum kwa vitendo vingi vya kipekee vya programu-jalizi. Kwa ujumla, hizi huja katika umbo lisilo na kikomo na la wakati uliopita - ambapo hali isiyo na kikomo (mf. show
) huanzishwa mwanzoni mwa tukio, na umbo lake la zamani la kishirikishi (mf. shown
) huanzishwa wakati kitendo kinapokamilika.
Matukio yote yasiyo na mwisho hutoa preventDefault()
utendaji. Hii hutoa uwezo wa kusimamisha utekelezaji wa kitendo kabla ya kuanza. Kurejesha uwongo kutoka kwa kidhibiti tukio pia kutapiga simu kiotomatiki preventDefault()
.
$('#myModal').on('show.bs.modal', function (event) {
if (!data) {
return event.preventDefault() // stops modal from being shown
}
})
Programu ya API
Pia tunaamini kuwa unapaswa kutumia programu jalizi zote za Bootstrap kupitia JavaScript API. API zote za umma ni mbinu moja, zinazoweza kuunganishwa, na hurejesha mkusanyiko uliochukuliwa hatua.
$('.btn.danger').button('toggle').addClass('fat')
Mbinu zote zinapaswa kukubali chaguo la chaguo la chaguo, mfuatano ambao unalenga mbinu fulani, au chochote (ambacho huanzisha programu-jalizi yenye tabia chaguo-msingi):
$('#myModal').modal() // initialized with defaults
$('#myModal').modal({ keyboard: false }) // initialized with no keyboard
$('#myModal').modal('show') // initializes and invokes show immediately
Kila programu-jalizi pia inafichua mjenzi wake mbichi kwenye Constructor
mali: $.fn.popover.Constructor
. Ikiwa ungependa kupata mfano fulani wa programu-jalizi, ipate moja kwa moja kutoka kwa kipengele: $('[rel="popover"]').data('popover')
.
Kazi na mabadiliko ya Asynchronous
Mbinu zote za API za kiprogramu hazifanani na hurudi kwa mpigaji simu mara tu mpito unapoanzishwa lakini kabla haujaisha .
Ili kutekeleza kitendo mara tu mpito utakapokamilika, unaweza kusikiliza tukio linalolingana.
$('#myCollapse').on('shown.bs.collapse', function (event) {
// Action to execute once the collapsible area is expanded
})
Kwa kuongezea, simu ya mbinu kwenye sehemu ya mpito itapuuzwa .
$('#myCarousel').on('slid.bs.carousel', function (event) {
$('#myCarousel').carousel('2') // Will slide to the slide 2 as soon as the transition to slide 1 is finished
})
$('#myCarousel').carousel('1') // Will start sliding to the slide 1 and returns to the caller
$('#myCarousel').carousel('2') // !! Will be ignored, as the transition to the slide 1 is not finished !!
Mipangilio chaguomsingi
Unaweza kubadilisha mipangilio chaguomsingi ya programu-jalizi kwa kurekebisha kipengee cha programu-jalizi Constructor.Default
:
// changes default for the modal plugin's `keyboard` option to false
$.fn.modal.Constructor.Default.keyboard = false
Hakuna mgongano
Wakati mwingine ni muhimu kutumia programu-jalizi za Bootstrap na mifumo mingine ya UI. Katika hali hizi, migongano ya nafasi ya majina inaweza kutokea mara kwa mara. Hili likitokea, unaweza kupiga simu .noConflict
kwenye programu-jalizi unayotaka kurejesha thamani yake.
var bootstrapButton = $.fn.button.noConflict() // return $.fn.button to previously assigned value
$.fn.bootstrapBtn = bootstrapButton // give $().bootstrapBtn the Bootstrap functionality
Nambari za toleo
Toleo la kila programu jalizi ya jQuery ya Bootstrap linaweza kufikiwa kupitia sifa ya VERSION
kijenzi cha programu-jalizi. Kwa mfano, kwa programu-jalizi ya zana:
$.fn.tooltip.Constructor.VERSION // => "4.6.2"
Hakuna njia mbadala maalum wakati JavaScript imezimwa
Programu-jalizi za Bootstrap hazirudi nyuma kwa uzuri haswa wakati JavaScript imezimwa. Iwapo unajali kuhusu matumizi ya mtumiaji katika kesi hii, tumia <noscript>
kueleza hali (na jinsi ya kuwezesha tena JavaScript) kwa watumiaji wako, na/au ongeza vikwazo vyako maalum.
Maktaba za watu wengine
Bootstrap haitumii rasmi maktaba za JavaScript za wahusika wengine kama Prototype au jQuery UI. Licha .noConflict
ya matukio na yaliyowekwa katika nafasi ya majina, kunaweza kuwa na matatizo ya uoanifu ambayo unahitaji kurekebisha peke yako.
Util
Faili zote za JavaScript za Bootstrap zinategemea util.js
na lazima zijumuishwe pamoja na faili zingine za JavaScript. Ikiwa unatumia compiled (au minified) bootstrap.js
, hakuna haja ya kujumuisha hii - tayari iko.
util.js
inajumuisha vipengele vya matumizi na msaidizi wa kimsingi wa transitionEnd
matukio pamoja na kiigaji cha mpito cha CSS. Inatumiwa na programu-jalizi zingine kuangalia usaidizi wa mpito wa CSS na kupata mabadiliko yanayoning'inia.
Sanitizer
Vidokezo vya zana na Popovers hutumia sanitizer yetu iliyojumuishwa ili kusafisha chaguzi zinazokubali HTML.
Thamani chaguo-msingi whiteList
ni ifuatayo:
var ARIA_ATTRIBUTE_PATTERN = /^aria-[\w-]*$/i
var DefaultWhitelist = {
// Global attributes allowed on any supplied element below.
'*': ['class', 'dir', 'id', 'lang', 'role', ARIA_ATTRIBUTE_PATTERN],
a: ['target', 'href', 'title', 'rel'],
area: [],
b: [],
br: [],
col: [],
code: [],
div: [],
em: [],
hr: [],
h1: [],
h2: [],
h3: [],
h4: [],
h5: [],
h6: [],
i: [],
img: ['src', 'srcset', 'alt', 'title', 'width', 'height'],
li: [],
ol: [],
p: [],
pre: [],
s: [],
small: [],
span: [],
sub: [],
sup: [],
strong: [],
u: [],
ul: []
}
Ikiwa unataka kuongeza maadili mapya kwa chaguo-msingi hili whiteList
unaweza kufanya yafuatayo:
var myDefaultWhiteList = $.fn.tooltip.Constructor.Default.whiteList
// To allow table elements
myDefaultWhiteList.table = []
// To allow td elements and data-option attributes on td elements
myDefaultWhiteList.td = ['data-option']
// You can push your custom regex to validate your attributes.
// Be careful about your regular expressions being too lax
var myCustomRegex = /^data-my-app-[\w-]+/
myDefaultWhiteList['*'].push(myCustomRegex)
Ikiwa ungependa kukwepa kisafishaji chetu kwa sababu unapendelea kutumia maktaba maalum, kwa mfano DOMpurify , unapaswa kufanya yafuatayo:
$('#yourTooltip').tooltip({
sanitizeFn: function (content) {
return DOMPurify.sanitize(content)
}
})