અભિગમ
બુટસ્ટ્રેપ બનાવવા અને જાળવવા માટે વપરાતા માર્ગદર્શક સિદ્ધાંતો, વ્યૂહરચનાઓ અને તકનીકો વિશે જાણો જેથી કરીને તમે તેને જાતે વધુ સરળતાથી કસ્ટમાઇઝ અને વિસ્તૃત કરી શકો.
જ્યારે શરૂઆતના પૃષ્ઠો પ્રોજેક્ટની પ્રારંભિક ટૂર પ્રદાન કરે છે અને તે શું ઓફર કરે છે, આ દસ્તાવેજ અમે બુટસ્ટ્રેપમાં જે કરીએ છીએ તે શા માટે કરીએ છીએ તેના પર ધ્યાન કેન્દ્રિત કરે છે. તે વેબ પર નિર્માણ કરવાની અમારી ફિલસૂફી સમજાવે છે જેથી કરીને અન્ય લોકો અમારી પાસેથી શીખી શકે, અમારી સાથે યોગદાન આપી શકે અને અમને સુધારવામાં મદદ કરી શકે.
એવું કંઈક જુઓ જે યોગ્ય લાગતું નથી, અથવા કદાચ વધુ સારું કરી શકાય? એક મુદ્દો ખોલો — અમને તમારી સાથે તેની ચર્ચા કરવાનું ગમશે.
અમે આમાંના દરેકમાં વધુ ડાઇવ કરીશું, પરંતુ ઉચ્ચ સ્તરે, અમારા અભિગમને માર્ગદર્શન આપે છે તે અહીં છે.
- ઘટકો પ્રતિભાવશીલ અને મોબાઇલ-પ્રથમ હોવા જોઈએ
- ઘટકોને બેઝ ક્લાસ સાથે બનાવવું જોઈએ અને મોડિફાયર ક્લાસ દ્વારા વિસ્તૃત કરવું જોઈએ
- ઘટક રાજ્યોએ સામાન્ય z-ઇન્ડેક્સ સ્કેલનું પાલન કરવું જોઈએ
- જ્યારે પણ શક્ય હોય ત્યારે, JavaScript પર HTML અને CSS અમલીકરણને પ્રાધાન્ય આપો
- જ્યારે પણ શક્ય હોય ત્યારે, કસ્ટમ શૈલીઓ પર ઉપયોગિતાઓનો ઉપયોગ કરો
- જ્યારે પણ શક્ય હોય, કડક HTML આવશ્યકતાઓને લાગુ કરવાનું ટાળો (બાળકો પસંદગીકારો)
બુટસ્ટ્રેપની રિસ્પોન્સિવ શૈલીઓ રિસ્પોન્સિવ બનવા માટે બનાવવામાં આવી છે, એક અભિગમ જેને ઘણીવાર મોબાઈલ-ફર્સ્ટ તરીકે ઓળખવામાં આવે છે . અમે અમારા દસ્તાવેજોમાં આ શબ્દનો ઉપયોગ કરીએ છીએ અને મોટાભાગે તેની સાથે સંમત છીએ, પરંતુ કેટલીકવાર તે ખૂબ વ્યાપક હોઈ શકે છે. જ્યારે દરેક ઘટક બુટસ્ટ્રેપમાં સંપૂર્ણપણે પ્રતિભાવશીલ હોવું જોઈએ નહીં, આ પ્રતિભાવશીલ અભિગમ તમને શૈલીઓ ઉમેરવા માટે દબાણ કરીને CSS ઓવરરાઇડ્સને ઘટાડવા વિશે છે કારણ કે વ્યુપોર્ટ મોટો થાય છે.
સમગ્ર બુટસ્ટ્રેપમાં, તમે અમારી મીડિયા ક્વેરીઝમાં આ સૌથી સ્પષ્ટ રીતે જોશો. મોટા ભાગના કિસ્સાઓમાં, અમે min-width
ક્વેરીઝનો ઉપયોગ કરીએ છીએ જે ચોક્કસ બ્રેકપોઇન્ટ પર લાગુ થવાનું શરૂ કરે છે અને ઉચ્ચ બ્રેકપોઇન્ટ દ્વારા આગળ વધે છે. ઉદાહરણ તરીકે, એક થી અનંત .d-none
સુધી લાગુ પડે છે . min-width: 0
બીજી બાજુ, .d-md-none
મધ્યમ બ્રેકપોઇન્ટ અને ઉપરથી એ લાગુ પડે છે.
અમુક સમયે અમે ઉપયોગ કરીશું max-width
જ્યારે ઘટકની અંતર્ગત જટિલતાને તેની જરૂર પડશે. અમુક સમયે, આ ઓવરરાઇડ્સ અમારા ઘટકોમાંથી મુખ્ય કાર્યક્ષમતાને ફરીથી લખવા કરતાં અમલીકરણ અને સમર્થન માટે કાર્યાત્મક અને માનસિક રીતે સ્પષ્ટ હોય છે. અમે આ અભિગમને મર્યાદિત કરવાનો પ્રયાસ કરીએ છીએ, પરંતુ સમયાંતરે તેનો ઉપયોગ કરીશું.
અમારા રીબૂટ સિવાય, ક્રોસ-બ્રાઉઝર નોર્મલાઇઝેશન સ્ટાઈલશીટ, અમારી બધી શૈલીઓ પસંદગીકારો તરીકે વર્ગોનો ઉપયોગ કરવાનું લક્ષ્ય રાખે છે. આનો અર્થ એ છે કે પ્રકાર પસંદગીકારો (દા.ત., input[type="text"]
) અને બાહ્ય પિતૃ વર્ગો (દા.ત., .parent .child
) કે જે શૈલીઓને સરળતાથી ઓવરરાઇડ કરવા માટે ખૂબ વિશિષ્ટ બનાવે છે તેનાથી સ્પષ્ટ સ્ટીયરિંગ.
જેમ કે, ઘટકોને બેઝ ક્લાસ સાથે બાંધવા જોઈએ જેમાં સામાન્ય, ઓવરરાઇડ ન થાય તેવી પ્રોપર્ટી-વેલ્યુ જોડી હોય. ઉદાહરણ તરીકે, .btn
અને .btn-primary
. અમે , , અને .btn
જેવી બધી સામાન્ય શૈલીઓ માટે ઉપયોગ કરીએ છીએ . અમે પછી રંગ, પૃષ્ઠભૂમિ-રંગ, સરહદ-રંગ, વગેરે ઉમેરવા માટે મોડિફાયરનો ઉપયોગ કરીએ છીએ .display
padding
border-width
.btn-primary
મોડિફાયર ક્લાસનો ઉપયોગ ત્યારે જ થવો જોઈએ જ્યારે બહુવિધ ગુણધર્મો અથવા મૂલ્યો બહુવિધ વેરિઅન્ટ્સમાં બદલવાના હોય. સંશોધકો હંમેશા જરૂરી હોતા નથી, તેથી ખાતરી કરો કે તમે કોડની રેખાઓ ખરેખર સાચવી રહ્યાં છો અને તેમને બનાવતી વખતે બિનજરૂરી ઓવરરાઇડ્સને અટકાવી રહ્યાં છો. સંશોધકોના સારા ઉદાહરણો અમારા થીમ રંગ વર્ગો અને કદના પ્રકારો છે.
બુટસ્ટ્રેપમાં બે z-index
સ્કેલ છે - ઘટકોની અંદર ઘટકો અને ઓવરલે ઘટકો.
- બુટસ્ટ્રેપમાં કેટલાક ઘટકો
border
પ્રોપર્ટીમાં ફેરફાર કર્યા વિના ડબલ બોર્ડર્સને રોકવા માટે ઓવરલેપિંગ તત્વો સાથે બાંધવામાં આવે છે. ઉદાહરણ તરીકે, બટન જૂથો, ઇનપુટ જૂથો અને પૃષ્ઠ ક્રમાંકન. - આ ઘટકો થ્રુ નું પ્રમાણભૂત
z-index
સ્કેલ શેર કરે છે .0
3
0
મૂળભૂત છે (પ્રારંભિક),1
is:hover
,2
is:active
/.active
, અને ,3
is:focus
.- આ અભિગમ સર્વોચ્ચ વપરાશકર્તા અગ્રતાની અમારી અપેક્ષાઓ સાથે મેળ ખાય છે. જો કોઈ તત્વ કેન્દ્રિત છે, તો તે દૃશ્યમાં છે અને વપરાશકર્તાના ધ્યાન પર છે. સક્રિય તત્વો બીજા ક્રમે છે કારણ કે તેઓ સ્થિતિ દર્શાવે છે. હોવર ત્રીજા સ્થાને સૌથી વધુ છે કારણ કે તે વપરાશકર્તાના ઉદ્દેશ્યને દર્શાવે છે, પરંતુ લગભગ કંઈપણ હોવર કરી શકાય છે.
બુટસ્ટ્રેપમાં કેટલાક ઘટકોનો સમાવેશ થાય છે જે અમુક પ્રકારના ઓવરલે તરીકે કાર્ય કરે છે. આમાં સર્વોચ્ચ ક્રમમાં z-index
, ડ્રોપડાઉન, નિશ્ચિત અને સ્ટીકી નેવબાર્સ, મોડલ્સ, ટૂલટિપ્સ અને પોપોવર્સનો સમાવેશ થાય છે. આ ઘટકોનો પોતાનો z-index
સ્કેલ છે જે થી શરૂ થાય છે 1000
. આ પ્રારંભિક નંબર રેન્ડમ છે અને અમારી શૈલીઓ અને તમારા પ્રોજેક્ટની કસ્ટમ શૈલીઓ વચ્ચે નાના બફર તરીકે સેવા આપે છે.
દરેક ઓવરલે ઘટક તેના z-index
મૂલ્યમાં થોડો વધારો કરે છે જેથી સામાન્ય UI સિદ્ધાંતો વપરાશકર્તાને કેન્દ્રિત અથવા હોવર કરેલ તત્વોને હંમેશા દૃશ્યમાં રહેવાની મંજૂરી આપે છે. ઉદાહરણ તરીકે, મોડલ એ ડોક્યુમેન્ટ બ્લોકીંગ છે (દા.ત., તમે મોડલની ક્રિયા સિવાય અન્ય કોઈ કાર્યવાહી કરી શકતા નથી), તેથી અમે તેને અમારા નેવબાર્સ ઉપર મૂકીએ છીએ.
z-index
અમારા લેઆઉટ પૃષ્ઠમાં આ વિશે વધુ જાણો .
જ્યારે પણ શક્ય હોય, અમે JavaScript પર HTML અને CSS લખવાનું પસંદ કરીએ છીએ. સામાન્ય રીતે, HTML અને CSS વધુ ફલપ્રદ અને તમામ વિવિધ અનુભવ સ્તરના વધુ લોકો માટે સુલભ છે. HTML અને CSS તમારા બ્રાઉઝરમાં JavaScript કરતાં વધુ ઝડપી છે, અને તમારું બ્રાઉઝર સામાન્ય રીતે તમારા માટે ઘણી બધી કાર્યક્ષમતા પ્રદાન કરે છે.
આ સિદ્ધાંત અમારી પ્રથમ-વર્ગની JavaScript API એ data
વિશેષતાઓ છે. અમારા JavaScript પ્લગિન્સનો ઉપયોગ કરવા માટે તમારે લગભગ કોઈપણ JavaScript લખવાની જરૂર નથી; તેના બદલે, HTML લખો. અમારા JavaScript વિહંગાવલોકન પૃષ્ઠમાં આ વિશે વધુ વાંચો .
છેલ્લે, અમારી શૈલીઓ સામાન્ય વેબ ઘટકોના મૂળભૂત વર્તણૂકો પર આધારિત છે. જ્યારે પણ શક્ય હોય, અમે બ્રાઉઝર જે પ્રદાન કરે છે તેનો ઉપયોગ કરવાનું પસંદ કરીએ છીએ. ઉદાહરણ તરીકે, તમે .btn
લગભગ કોઈપણ એલિમેન્ટ પર ક્લાસ મૂકી શકો છો, પરંતુ મોટાભાગના એલિમેન્ટ્સ કોઈપણ સિમેન્ટીક મૂલ્ય અથવા બ્રાઉઝર કાર્યક્ષમતા પ્રદાન કરતા નથી. તેથી તેના બદલે, અમે <button>
s અને <a>
s નો ઉપયોગ કરીએ છીએ.
તે જ વધુ જટિલ ઘટકો માટે જાય છે. જ્યારે અમે ઇનપુટની સ્થિતિ પર આધારિત પેરેંટ એલિમેન્ટમાં વર્ગો ઉમેરવા માટે આપણું પોતાનું ફોર્મ માન્યતા પ્લગઇન લખી શકીએ છીએ, ત્યાં અમને લખાણને લાલ કહેવાની શૈલીની મંજૂરી આપીએ છીએ, અમે દરેક બ્રાઉઝર અમને પ્રદાન કરે છે તે / સ્યુડો-તત્વોનો ઉપયોગ કરવાનું પસંદ કરીએ:valid
છીએ :invalid
.
ઉપયોગિતા વર્ગો-અગાઉ બુટસ્ટ્રેપ 3 માં મદદગારો-CSS બ્લોટ અને નબળા પૃષ્ઠ પ્રદર્શન સામે લડવામાં શક્તિશાળી સાથી છે. યુટિલિટી ક્લાસ એ સામાન્ય રીતે સિંગલ, અપરિવર્તનશીલ પ્રોપર્ટી-વેલ્યુ પેરિંગ છે જે વર્ગ તરીકે વ્યક્ત થાય છે (દા.ત., .d-block
રજૂ કરે છે display: block;
). તેમની પ્રાથમિક અપીલ HTML લખતી વખતે ઉપયોગની ઝડપ અને તમારે લખવા માટેના કસ્ટમ CSSની માત્રાને મર્યાદિત કરવી છે.
ખાસ કરીને કસ્ટમ CSS સંબંધિત, ઉપયોગિતાઓ તમારી સૌથી સામાન્ય રીતે પુનરાવર્તિત પ્રોપર્ટી-વેલ્યુ જોડીને સિંગલ ક્લાસમાં ઘટાડીને ફાઈલના કદમાં વધારો સામે લડવામાં મદદ કરી શકે છે. આ તમારા પ્રોજેક્ટ્સમાં સ્કેલ પર નાટ્યાત્મક અસર કરી શકે છે.
હંમેશા શક્ય ન હોવા છતાં, અમે ઘટકો માટેની અમારી HTML આવશ્યકતાઓમાં વધુ પડતા કટ્ટરપંથી બનવાનું ટાળવાનો પ્રયત્ન કરીએ છીએ. આમ, અમે અમારા CSS પસંદગીકારોમાં એક વર્ગ પર ધ્યાન કેન્દ્રિત કરીએ છીએ અને તાત્કાલિક બાળકો પસંદગીકારોને ટાળવાનો પ્રયાસ કરીએ છીએ ( >
). આ તમને તમારા અમલીકરણમાં વધુ સુગમતા આપે છે અને અમારા CSSને સરળ અને ઓછા વિશિષ્ટ રાખવામાં મદદ કરે છે.