जावास्क्रिप्ट्
jQuery इत्यत्र निर्मितेन अस्माकं वैकल्पिकजावास्क्रिप्ट् प्लगिन्स् इत्यनेन सह Bootstrap इत्यस्य जीवनं आनयन्तु। प्रत्येकस्य प्लगिन्, अस्माकं आँकडानां तथा प्रोग्रामेटिक एपिआइ विकल्पानां विषये, इत्यादीनां विषये ज्ञातव्यम्।
प्लगिन् व्यक्तिगतरूपेण (Bootstrap इत्यस्य व्यक्तिगतस्य उपयोगेन js/dist/*.js
), अथवा सर्वे एकदा एव उपयुज्य bootstrap.js
वा लघुकृतं वा bootstrap.min.js
(उभयम् अपि न समाविष्टं) समाविष्टं कर्तुं शक्यते ।
यदि भवान् बण्डलर (Webpack, Rollup...) इत्यस्य उपयोगं करोति तर्हि भवान् तादृशानि /js/dist/*.js
सञ्चिकानि उपयोक्तुं शक्नोति ये UMD सज्जाः सन्ति ।
केचन प्लगिन्स् तथा CSS घटकाः अन्येषु प्लगिन्स् इत्यस्य उपरि निर्भराः सन्ति । यदि भवान् प्लगिन्स् व्यक्तिगतरूपेण समावेशयति तर्हि docs मध्ये एतानि आश्रयाणि अवश्यं पश्यतु । इदमपि ज्ञातव्यं यत् सर्वे प्लगिन्स् jQuery इत्यस्य उपरि निर्भराः सन्ति (अस्य अर्थः अस्ति यत् प्लगिन् सञ्चिकाभ्यः पूर्वं jQuery इत्येतत् अवश्यमेव समाविष्टं भवेत् ) । jQuery इत्यस्य के के संस्करणाः समर्थिताः सन्ति इति द्रष्टुं अस्माकं परामर्शं कुर्वन्तु ।package.json
अस्माकं dropdowns, popovers तथा tooltips अपि Popper.js इत्यस्य उपरि निर्भरं भवति ।
प्रायः सर्वाणि Bootstrap प्लगिन्स् केवलं HTML मार्गेण data attributes (JavaScript कार्यक्षमतायाः उपयोगस्य अस्माकं प्राधान्यमार्गः) सह सक्षमीकरणं विन्यस्तं च कर्तुं शक्यते । एकस्मिन् तत्त्वे केवलं एकस्य दत्तांशगुणसमूहस्य उपयोगं अवश्यं कुर्वन्तु (उदा., भवान् एकस्मात् बटन् तः टूल्टिप् तथा मोडल् ट्रिगर कर्तुं न शक्नोति ।)
परन्तु केषुचित् परिस्थितिषु एतत् कार्यं निष्क्रियं कर्तुं इष्टं भवेत् । data attribute API अक्षमीकरणाय, एतादृशेन सह नामस्थानं कृत्वा दस्तावेजे सर्वाणि घटनानि अनबाइण्ड् कुर्वन्तु data-api
:
वैकल्पिकरूपेण, विशिष्टं प्लगिन् लक्ष्यं कर्तुं, केवलं प्लगिन् नाम नामस्थानरूपेण data-api नामस्थानेन सह एतादृशं समावेशयन्तु:
पलायन चयनकर्ता
यदि भवान् विशेषचयनकर्तृणां उपयोगं करोति, उदाहरणार्थं: collapse:Example
, तेभ्यः अवश्यं पलायितुं शक्नोति, यतः ते jQuery मार्गेण गच्छन्ति ।
बूटस्ट्रैप् अधिकांशस्य प्लगिन्स् इत्यस्य विशिष्टक्रियाणां कृते इष्टघटनानि प्रदाति । सामान्यतः ये अव्यय एवं भूतकाल में आते हैं - जहाँ अव्यय (ex. show
) किसी घटना के आरम्भ में प्रेरित होता है, तथा उसका भूतकालरूप (ex. shown
) किसी क्रिया के समाप्त होने पर प्रेरित होता है।
सर्वाणि अव्ययघटनानि preventDefault()
कार्यक्षमतां प्रददति। एतेन क्रियायाः आरम्भात् पूर्वं निष्पादनं निवारयितुं क्षमता प्राप्यते । इवेण्ट् हन्ड्लर इत्यस्मात् false इति प्रत्यागच्छन् स्वयमेव अपि आह्वयति preventDefault()
|
वयम् अपि मन्यामहे यत् भवान् सर्वान् Bootstrap प्लगिन्स् केवलं जावास्क्रिप्ट् एपिआइ मार्गेण उपयोक्तुं समर्थः भवेत् । सर्वे सार्वजनिक एपिआइ एकाः, श्रृङ्खलायोग्याः पद्धतयः सन्ति, तथा च कार्यं कृतं संग्रहं प्रत्यागच्छन्ति ।
सर्वैः विधिभिः वैकल्पिकविकल्पवस्तुं, एकं स्ट्रिंग् यत् विधिविशेषं लक्ष्यते, अथवा किमपि न (यत् पूर्वनिर्धारितव्यवहारेन सह प्लगिन् आरभते) स्वीकुर्वीत:
प्रत्येकं प्लगिन् अपि एकस्मिन् Constructor
गुणे स्वस्य कच्चा कन्स्ट्रक्टर् उजागरयति: $.fn.popover.Constructor
. यदि भवान् कञ्चन विशेषं प्लगिन् उदाहरणं प्राप्तुम् इच्छति तर्हि तत् प्रत्यक्षतया कस्मात् तत्त्वात् पुनः प्राप्तुम् इच्छति: $('[rel="popover"]').data('popover')
.
सर्वे प्रोग्रामेटिक एपिआइ मेथड् एसिंक्रोन्स् भवन्ति तथा च एकवारं संक्रमणस्य आरम्भे परन्तु समाप्तेः पूर्वं आह्वानकर्त्रे प्रत्यागच्छन्ति |
एकवारं संक्रमणं सम्पन्नं जातं चेत् क्रियायाः निष्पादनार्थं भवन्तः तत्सम्बद्धं घटनां श्रोतुं शक्नुवन्ति ।
तदतिरिक्तं संक्रमणघटकस्य उपरि एकं मेथड् आह्वानं उपेक्षितं भविष्यति |
Constructor.Default
प्लगिन् इत्यस्य वस्तु परिवर्त्य भवान् प्लगिन् इत्यस्य पूर्वनिर्धारितसेटिंग्स् परिवर्तयितुं शक्नोति :
कदाचित् अन्यैः UI frameworks इत्यनेन सह Bootstrap plugins इत्यस्य उपयोगः आवश्यकः भवति । एतेषु परिस्थितिषु नामस्थानस्य टकरावः यदा कदा भवितुं शक्नुवन्ति । यदि एतत् भवति तर्हि भवान् .noConflict
यस्य प्लगिन् इत्यस्य मूल्यं पुनः प्रत्यागन्तुं इच्छति तत् आह्वयितुं शक्नोति ।
Bootstrap इत्यस्य प्रत्येकस्य jQuery प्लगिन् इत्यस्य संस्करणं VERSION
प्लगिन् इत्यस्य कन्स्ट्रक्टर् इत्यस्य गुणद्वारा अभिगन्तुं शक्यते । यथा, टूल्टिप् प्लगिन् कृते :
बूटस्ट्रैप् इत्यस्य प्लगिन्स् विशेषतया ललितरूपेण न पतन्ति यदा जावास्क्रिप्ट् अक्षमम् अस्ति । यदि भवान् अस्मिन् सन्दर्भे उपयोक्तृअनुभवस्य चिन्तां करोति तर्हि <noscript>
स्थितिं व्याख्यातुं (तथा च जावास्क्रिप्ट् कथं पुनः सक्षमीकरणीयम्) स्वप्रयोक्तृभ्यः, तथा/वा स्वकीयानि कस्टम् फॉलबैक् योजयितुं उपयुज्यताम्
तृतीयपक्षीयपुस्तकालयाः
बूटस्ट्रैप् आधिकारिकतया तृतीयपक्षस्य जावास्क्रिप्ट् पुस्तकालयानाम् समर्थनं न करोति यथा Prototype अथवा jQuery UI । अपि .noConflict
च नामान्तरितघटनानां, संगततासमस्याः भवितुम् अर्हन्ति येषां समाधानं भवद्भिः स्वयमेव करणीयम् ।
Bootstrap इत्यस्य सर्वाणि JavaScript सञ्चिकाः निर्भराः सन्ति util.js
तथा च अन्येषां JavaScript सञ्चिकानां पार्श्वे एतत् समाविष्टं कर्तव्यम् अस्ति । यदि भवान् संकलितं (अथवा लघुकृतं) उपयुज्यते तर्हि bootstrap.js
एतत् समावेशयितुं आवश्यकता नास्ति—इदं पूर्वमेव अस्ति ।
util.js
transitionEnd
उपयोगिता कार्याणि तथा घटनानां कृते मूलभूतसहायकं तथा च CSS संक्रमण अनुकरणकं समाविष्टम् अस्ति । अन्यैः प्लगिन्स् द्वारा CSS संक्रमणसमर्थनस्य जाँचार्थं तथा लम्बमानसंक्रमणानि ग्रहीतुं तस्य उपयोगः भवति ।