Navs અને ટેબ
બુટસ્ટ્રેપના સમાવિષ્ટ નેવિગેશન ઘટકોનો ઉપયોગ કેવી રીતે કરવો તેના માટે દસ્તાવેજીકરણ અને ઉદાહરણો.
બેઝ એનએવી
બુટસ્ટ્રેપમાં ઉપલબ્ધ નેવિગેશન સામાન્ય માર્કઅપ અને શૈલીઓ શેર કરે છે, બેઝ .nav
ક્લાસથી સક્રિય અને અક્ષમ સ્થિતિઓ સુધી. દરેક શૈલી વચ્ચે સ્વિચ કરવા માટે સંશોધક વર્ગોને સ્વેપ કરો.
બેઝ .nav
કમ્પોનન્ટ ફ્લેક્સબોક્સ સાથે બનેલ છે અને તમામ પ્રકારના નેવિગેશન ઘટકોના નિર્માણ માટે મજબૂત પાયો પૂરો પાડે છે. તેમાં કેટલાક સ્ટાઇલ ઓવરરાઇડ્સ (સૂચિઓ સાથે કામ કરવા માટે), મોટા હિટ વિસ્તારો માટે કેટલાક લિંક પેડિંગ અને મૂળભૂત અક્ષમ શૈલીનો સમાવેશ થાય છે.
આધાર .nav
ઘટકમાં કોઈપણ .active
રાજ્યનો સમાવેશ થતો નથી. નીચેના ઉદાહરણોમાં વર્ગનો સમાવેશ થાય છે, મુખ્યત્વે તે દર્શાવવા માટે કે આ ચોક્કસ વર્ગ કોઈ વિશિષ્ટ શૈલીને ટ્રિગર કરતું નથી.
સક્રિય સ્થિતિને સહાયક તકનીકો સુધી પહોંચાડવા માટે, aria-current
વિશેષતાનો ઉપયોગ કરો — page
વર્તમાન પૃષ્ઠ માટે મૂલ્યનો ઉપયોગ કરીને અથવા true
સમૂહમાં વર્તમાન આઇટમ માટે.
<ul class="nav">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
સમગ્ર વર્ગોનો ઉપયોગ કરવામાં આવે છે, તેથી તમારું માર્કઅપ સુપર લવચીક બની શકે છે. જો તમારી વસ્તુઓનો ક્રમ મહત્વનો હોય તો <ul>
ઉપરની જેમ s નો ઉપયોગ કરો અથવા તત્વ સાથે તમારી પોતાની રોલ કરો. કારણ કે ઉપયોગો , nav લિંક્સ એ જ રીતે વર્તે છે જે NAV વસ્તુઓ કરે છે, પરંતુ વધારાના માર્કઅપ વિના.<ol>
<nav>
.nav
display: flex
<nav class="nav">
<a class="nav-link active" aria-current="page" href="#">Active</a>
<a class="nav-link" href="#">Link</a>
<a class="nav-link" href="#">Link</a>
<a class="nav-link disabled">Disabled</a>
</nav>
ઉપલબ્ધ શૈલીઓ
.nav
સંશોધકો અને ઉપયોગિતાઓ સાથે s ઘટકની શૈલી બદલો . જરૂર મુજબ મિક્સ કરો અને મેચ કરો અથવા તમારા પોતાના બનાવો.
આડી ગોઠવણી
ફ્લેક્સબોક્સ યુટિલિટીઝ સાથે તમારા nav ની આડી ગોઠવણી બદલો . ડિફૉલ્ટ રૂપે, navs ડાબે સંરેખિત હોય છે, પરંતુ તમે તેમને સરળતાથી મધ્યમાં અથવા જમણે સંરેખિતમાં બદલી શકો છો.
સાથે કેન્દ્રિત .justify-content-center
:
<ul class="nav justify-content-center">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
આની સાથે જમણે સંરેખિત .justify-content-end
:
<ul class="nav justify-content-end">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
વર્ટિકલ
.flex-column
ઉપયોગિતા સાથે ફ્લેક્સ આઇટમની દિશા બદલીને તમારા નેવિગેશનને સ્ટેક કરો . તેમને કેટલાક વ્યુપોર્ટ પર સ્ટેક કરવાની જરૂર છે પરંતુ અન્ય પર નહીં? રિસ્પોન્સિવ વર્ઝનનો ઉપયોગ કરો (દા.ત., .flex-sm-column
).
<ul class="nav flex-column">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
હંમેશની જેમ, વર્ટિકલ નેવિગેશન <ul>
s વિના પણ શક્ય છે.
<nav class="nav flex-column">
<a class="nav-link active" aria-current="page" href="#">Active</a>
<a class="nav-link" href="#">Link</a>
<a class="nav-link" href="#">Link</a>
<a class="nav-link disabled">Disabled</a>
</nav>
ટૅબ્સ
ઉપરથી મૂળભૂત એનએવી લે છે અને .nav-tabs
ટેબ કરેલ ઈન્ટરફેસ જનરેટ કરવા માટે વર્ગ ઉમેરે છે. અમારા ટૅબ JavaScript પ્લગઇન સાથે ટેબેબલ પ્રદેશો બનાવવા માટે તેનો ઉપયોગ કરો .
<ul class="nav nav-tabs">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
ગોળીઓ
તે જ HTML લો, પરંતુ .nav-pills
તેના બદલે ઉપયોગ કરો:
<ul class="nav nav-pills">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
ભરો અને ન્યાયી
.nav
તમારા સમાવિષ્ટોને સંપૂર્ણ ઉપલબ્ધ પહોળાઈને બે મોડિફાયર વર્ગોમાંથી એક વિસ્તારવા માટે દબાણ કરો . .nav-item
તમારા s સાથે બધી ઉપલબ્ધ જગ્યાને પ્રમાણસર ભરવા માટે , ઉપયોગ કરો .nav-fill
. નોંધ લો કે બધી આડી જગ્યા કબજે છે, પરંતુ દરેક નેવી આઇટમની પહોળાઈ સમાન નથી.
<ul class="nav nav-pills nav-fill">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Much longer nav link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
-આધારિત નેવિગેશનનો ઉપયોગ કરતી વખતે <nav>
, તમે સુરક્ષિત રીતે છોડી શકો છો .nav-item
કારણ કે માત્ર .nav-link
સ્ટાઇલ <a>
તત્વો માટે જરૂરી છે.
<nav class="nav nav-pills nav-fill">
<a class="nav-link active" aria-current="page" href="#">Active</a>
<a class="nav-link" href="#">Much longer nav link</a>
<a class="nav-link" href="#">Link</a>
<a class="nav-link disabled">Disabled</a>
</nav>
સમાન-પહોળાઈના ઘટકો માટે, ઉપયોગ કરો .nav-justified
. બધી આડી જગ્યા નેવી લિંક્સ દ્વારા કબજે કરવામાં આવશે, પરંતુ ઉપરોક્તથી વિપરીત .nav-fill
, દરેક નેવી આઇટમ સમાન પહોળાઈની હશે.
<ul class="nav nav-pills nav-justified">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Much longer nav link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
-આધારિત નેવિગેશનનો ઉપયોગ કરીને .nav-fill
ઉદાહરણ જેવું જ.<nav>
<nav class="nav nav-pills nav-justified">
<a class="nav-link active" aria-current="page" href="#">Active</a>
<a class="nav-link" href="#">Much longer nav link</a>
<a class="nav-link" href="#">Link</a>
<a class="nav-link disabled">Disabled</a>
</nav>
ફ્લેક્સ ઉપયોગિતાઓ સાથે કામ કરવું
જો તમને રિસ્પોન્સિવ નેવી ભિન્નતાની જરૂર હોય, તો ફ્લેક્સબોક્સ ઉપયોગિતાઓની શ્રેણીનો ઉપયોગ કરવાનું વિચારો . વધુ વર્બોઝ હોવા છતાં, આ ઉપયોગિતાઓ પ્રતિભાવાત્મક બ્રેકપોઇન્ટ્સમાં વધુ કસ્ટમાઇઝેશન ઓફર કરે છે. નીચેના ઉદાહરણમાં, અમારું nav સૌથી નીચા બ્રેકપોઇન્ટ પર સ્ટેક કરવામાં આવશે, પછી નાના બ્રેકપોઇન્ટથી શરૂ કરીને ઉપલબ્ધ પહોળાઈને ભરે તેવા આડા લેઆઉટને અનુકૂલિત થશે.
<nav class="nav nav-pills flex-column flex-sm-row">
<a class="flex-sm-fill text-sm-center nav-link active" aria-current="page" href="#">Active</a>
<a class="flex-sm-fill text-sm-center nav-link" href="#">Longer nav link</a>
<a class="flex-sm-fill text-sm-center nav-link" href="#">Link</a>
<a class="flex-sm-fill text-sm-center nav-link disabled">Disabled</a>
</nav>
સુલભતા અંગે
જો તમે નેવિગેશન બાર પ્રદાન કરવા માટે navs નો ઉપયોગ કરી રહ્યાં છો, તો role="navigation"
ના સૌથી તાર્કિક પેરેન્ટ કન્ટેનરમાં ઉમેરવાની ખાતરી કરો અથવા સમગ્ર નેવિગેશનની આસપાસ <ul>
એક તત્વ લપેટી લો. <nav>
ભૂમિકાને <ul>
પોતાનામાં ઉમેરો નહીં, કારણ કે આ સહાયક તકનીકો દ્વારા તેને વાસ્તવિક સૂચિ તરીકે જાહેર કરવામાં અટકાવશે.
નોંધ કરો કે નેવિગેશન બાર, જો .nav-tabs
વર્ગ સાથે ટેબ્સ તરીકે દૃષ્ટિની રીતે સ્ટાઈલ કરવામાં આવે તો પણ , , અથવા વિશેષતાઓ આપવી જોઈએ નહીં . આ ફક્ત ડાયનેમિક ટેબવાળા ઈન્ટરફેસ માટે જ યોગ્ય છે, જેમ કે ARIA ઓથરિંગ પ્રેક્ટિસ ગાઈડ ટેબ પેટર્નમાં વર્ણવેલ છે . ઉદાહરણ માટે આ વિભાગમાં ડાયનેમિક ટૅબ કરેલ ઇન્ટરફેસ માટે JavaScript વર્તન જુઓ . ડાયનેમિક ટેબવાળા ઈન્ટરફેસ પર વિશેષતા જરૂરી નથી કારણ કે અમારી JavaScript સક્રિય ટેબ પર ઉમેરીને પસંદ કરેલી સ્થિતિને હેન્ડલ કરે છે.role="tablist"
role="tab"
role="tabpanel"
aria-current
aria-selected="true"
ડ્રોપડાઉનનો ઉપયોગ કરીને
થોડા વધારાના HTML અને ડ્રોપડાઉન JavaScript પ્લગઇન સાથે ડ્રોપડાઉન મેનુ ઉમેરો .
ડ્રોપડાઉન સાથે ટૅબ્સ
<ul class="nav nav-tabs">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" data-bs-toggle="dropdown" href="#" role="button" aria-expanded="false">Dropdown</a>
<ul class="dropdown-menu">
<li><a class="dropdown-item" href="#">Action</a></li>
<li><a class="dropdown-item" href="#">Another action</a></li>
<li><a class="dropdown-item" href="#">Something else here</a></li>
<li><hr class="dropdown-divider"></li>
<li><a class="dropdown-item" href="#">Separated link</a></li>
</ul>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
ડ્રોપડાઉન સાથે ગોળીઓ
<ul class="nav nav-pills">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Active</a>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" data-bs-toggle="dropdown" href="#" role="button" aria-expanded="false">Dropdown</a>
<ul class="dropdown-menu">
<li><a class="dropdown-item" href="#">Action</a></li>
<li><a class="dropdown-item" href="#">Another action</a></li>
<li><a class="dropdown-item" href="#">Something else here</a></li>
<li><hr class="dropdown-divider"></li>
<li><a class="dropdown-item" href="#">Separated link</a></li>
</ul>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
CSS
ચલો
v5.2.0 માં ઉમેરાયેલબુટસ્ટ્રેપના વિકસતા CSS ચલોના અભિગમના ભાગરૂપે, navs હવે .nav
, .nav-tabs
, અને .nav-pills
ઉન્નત રીઅલ-ટાઇમ કસ્ટમાઇઝેશન માટે સ્થાનિક CSS ચલોનો ઉપયોગ કરે છે. CSS ચલો માટેના મૂલ્યો Sass દ્વારા સેટ કરવામાં આવ્યા છે, તેથી Sass કસ્ટમાઇઝેશન હજુ પણ સપોર્ટેડ છે.
.nav
બેઝ ક્લાસ પર :
--#{$prefix}nav-link-padding-x: #{$nav-link-padding-x};
--#{$prefix}nav-link-padding-y: #{$nav-link-padding-y};
@include rfs($nav-link-font-size, --#{$prefix}nav-link-font-size);
--#{$prefix}nav-link-font-weight: #{$nav-link-font-weight};
--#{$prefix}nav-link-color: #{$nav-link-color};
--#{$prefix}nav-link-hover-color: #{$nav-link-hover-color};
--#{$prefix}nav-link-disabled-color: #{$nav-link-disabled-color};
.nav-tabs
સુધારક વર્ગ પર :
--#{$prefix}nav-tabs-border-width: #{$nav-tabs-border-width};
--#{$prefix}nav-tabs-border-color: #{$nav-tabs-border-color};
--#{$prefix}nav-tabs-border-radius: #{$nav-tabs-border-radius};
--#{$prefix}nav-tabs-link-hover-border-color: #{$nav-tabs-link-hover-border-color};
--#{$prefix}nav-tabs-link-active-color: #{$nav-tabs-link-active-color};
--#{$prefix}nav-tabs-link-active-bg: #{$nav-tabs-link-active-bg};
--#{$prefix}nav-tabs-link-active-border-color: #{$nav-tabs-link-active-border-color};
.nav-pills
સુધારક વર્ગ પર :
--#{$prefix}nav-pills-border-radius: #{$nav-pills-border-radius};
--#{$prefix}nav-pills-link-active-color: #{$nav-pills-link-active-color};
--#{$prefix}nav-pills-link-active-bg: #{$nav-pills-link-active-bg};
Sass ચલો
$nav-link-padding-y: .5rem;
$nav-link-padding-x: 1rem;
$nav-link-font-size: null;
$nav-link-font-weight: null;
$nav-link-color: var(--#{$prefix}link-color);
$nav-link-hover-color: var(--#{$prefix}link-hover-color);
$nav-link-transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out;
$nav-link-disabled-color: $gray-600;
$nav-tabs-border-color: $gray-300;
$nav-tabs-border-width: $border-width;
$nav-tabs-border-radius: $border-radius;
$nav-tabs-link-hover-border-color: $gray-200 $gray-200 $nav-tabs-border-color;
$nav-tabs-link-active-color: $gray-700;
$nav-tabs-link-active-bg: $body-bg;
$nav-tabs-link-active-border-color: $gray-300 $gray-300 $nav-tabs-link-active-bg;
$nav-pills-border-radius: $border-radius;
$nav-pills-link-active-color: $component-active-color;
$nav-pills-link-active-bg: $component-active-bg;
JavaScript વર્તન
ટૅબ JavaScript પ્લગઇનનો ઉપયોગ કરો-તેને વ્યક્તિગત રીતે અથવા સંકલિત bootstrap.js
ફાઇલ દ્વારા શામેલ કરો-સ્થાનિક સામગ્રીના ટેબેબલ પેન બનાવવા માટે અમારા નેવિગેશનલ ટૅબ્સ અને ગોળીઓને વિસ્તારવા માટે.
આ અમુક પ્લેસહોલ્ડર સામગ્રી છે જે હોમ ટેબની સંબંધિત સામગ્રી છે. બીજા ટેબ પર ક્લિક કરવાથી આની દૃશ્યતા આગામી માટે ટૉગલ થઈ જશે. ટેબ JavaScript સામગ્રીની દૃશ્યતા અને સ્ટાઇલને નિયંત્રિત કરવા માટે વર્ગોને સ્વેપ કરે છે. તમે તેનો ઉપયોગ ટેબ્સ, ગોળીઓ અને અન્ય કોઈપણ .nav
સંચાલિત નેવિગેશન સાથે કરી શકો છો.
This is some placeholder content the Profile tab's associated content. Clicking another tab will toggle the visibility of this one for the next. The tab JavaScript swaps classes to control the content visibility and styling. You can use it with tabs, pills, and any other .nav
-powered navigation.
This is some placeholder content the Contact tab's associated content. Clicking another tab will toggle the visibility of this one for the next. The tab JavaScript swaps classes to control the content visibility and styling. You can use it with tabs, pills, and any other .nav
-powered navigation.
This is some placeholder content the Disabled tab's associated content.
<ul class="nav nav-tabs" id="myTab" role="tablist">
<li class="nav-item" role="presentation">
<button class="nav-link active" id="home-tab" data-bs-toggle="tab" data-bs-target="#home-tab-pane" type="button" role="tab" aria-controls="home-tab-pane" aria-selected="true">Home</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="profile-tab" data-bs-toggle="tab" data-bs-target="#profile-tab-pane" type="button" role="tab" aria-controls="profile-tab-pane" aria-selected="false">Profile</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="contact-tab" data-bs-toggle="tab" data-bs-target="#contact-tab-pane" type="button" role="tab" aria-controls="contact-tab-pane" aria-selected="false">Contact</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="disabled-tab" data-bs-toggle="tab" data-bs-target="#disabled-tab-pane" type="button" role="tab" aria-controls="disabled-tab-pane" aria-selected="false" disabled>Disabled</button>
</li>
</ul>
<div class="tab-content" id="myTabContent">
<div class="tab-pane fade show active" id="home-tab-pane" role="tabpanel" aria-labelledby="home-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="profile-tab-pane" role="tabpanel" aria-labelledby="profile-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="contact-tab-pane" role="tabpanel" aria-labelledby="contact-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="disabled-tab-pane" role="tabpanel" aria-labelledby="disabled-tab" tabindex="0">...</div>
</div>
તમારી જરૂરિયાતોને પૂર્ણ કરવામાં મદદ કરવા માટે, આ <ul>
ઉપર બતાવ્યા પ્રમાણે -આધારિત માર્કઅપ સાથે અથવા કોઈપણ મનસ્વી "તમારા પોતાના રોલ" માર્કઅપ સાથે કામ કરે છે. નોંધ કરો કે જો તમે ઉપયોગ કરી રહ્યાં છો , તો તમારે તેમાં સીધું <nav>
ઉમેરવું જોઈએ નહીં role="tablist"
, કારણ કે આ નેવિગેશન સીમાચિહ્ન તરીકે તત્વની મૂળ ભૂમિકાને ઓવરરાઇડ કરશે. તેના બદલે, વૈકલ્પિક તત્વ પર સ્વિચ કરો (નીચેના ઉદાહરણમાં, એક સરળ <div>
) અને તેની <nav>
આસપાસ લપેટો.
<nav>
<div class="nav nav-tabs" id="nav-tab" role="tablist">
<button class="nav-link active" id="nav-home-tab" data-bs-toggle="tab" data-bs-target="#nav-home" type="button" role="tab" aria-controls="nav-home" aria-selected="true">Home</button>
<button class="nav-link" id="nav-profile-tab" data-bs-toggle="tab" data-bs-target="#nav-profile" type="button" role="tab" aria-controls="nav-profile" aria-selected="false">Profile</button>
<button class="nav-link" id="nav-contact-tab" data-bs-toggle="tab" data-bs-target="#nav-contact" type="button" role="tab" aria-controls="nav-contact" aria-selected="false">Contact</button>
<button class="nav-link" id="nav-disabled-tab" data-bs-toggle="tab" data-bs-target="#nav-disabled" type="button" role="tab" aria-controls="nav-disabled" aria-selected="false" disabled>Disabled</button>
</div>
</nav>
<div class="tab-content" id="nav-tabContent">
<div class="tab-pane fade show active" id="nav-home" role="tabpanel" aria-labelledby="nav-home-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="nav-profile" role="tabpanel" aria-labelledby="nav-profile-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="nav-contact" role="tabpanel" aria-labelledby="nav-contact-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="nav-disabled" role="tabpanel" aria-labelledby="nav-disabled-tab" tabindex="0">...</div>
</div>
ટૅબ્સ પ્લગઇન ગોળીઓ સાથે પણ કામ કરે છે.
આ અમુક પ્લેસહોલ્ડર સામગ્રી છે જે હોમ ટેબની સંબંધિત સામગ્રી છે. બીજા ટેબ પર ક્લિક કરવાથી આની દૃશ્યતા આગામી માટે ટૉગલ થઈ જશે. ટેબ JavaScript સામગ્રીની દૃશ્યતા અને સ્ટાઇલને નિયંત્રિત કરવા માટે વર્ગોને સ્વેપ કરે છે. તમે તેનો ઉપયોગ ટેબ્સ, ગોળીઓ અને અન્ય કોઈપણ .nav
સંચાલિત નેવિગેશન સાથે કરી શકો છો.
This is some placeholder content the Profile tab's associated content. Clicking another tab will toggle the visibility of this one for the next. The tab JavaScript swaps classes to control the content visibility and styling. You can use it with tabs, pills, and any other .nav
-powered navigation.
This is some placeholder content the Contact tab's associated content. Clicking another tab will toggle the visibility of this one for the next. The tab JavaScript swaps classes to control the content visibility and styling. You can use it with tabs, pills, and any other .nav
-powered navigation.
This is some placeholder content the Disabled tab's associated content.
<ul class="nav nav-pills mb-3" id="pills-tab" role="tablist">
<li class="nav-item" role="presentation">
<button class="nav-link active" id="pills-home-tab" data-bs-toggle="pill" data-bs-target="#pills-home" type="button" role="tab" aria-controls="pills-home" aria-selected="true">Home</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="pills-profile-tab" data-bs-toggle="pill" data-bs-target="#pills-profile" type="button" role="tab" aria-controls="pills-profile" aria-selected="false">Profile</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="pills-contact-tab" data-bs-toggle="pill" data-bs-target="#pills-contact" type="button" role="tab" aria-controls="pills-contact" aria-selected="false">Contact</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="pills-disabled-tab" data-bs-toggle="pill" data-bs-target="#pills-disabled" type="button" role="tab" aria-controls="pills-disabled" aria-selected="false" disabled>Disabled</button>
</li>
</ul>
<div class="tab-content" id="pills-tabContent">
<div class="tab-pane fade show active" id="pills-home" role="tabpanel" aria-labelledby="pills-home-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="pills-profile" role="tabpanel" aria-labelledby="pills-profile-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="pills-contact" role="tabpanel" aria-labelledby="pills-contact-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="pills-disabled" role="tabpanel" aria-labelledby="pills-disabled-tab" tabindex="0">...</div>
</div>
અને ઊભી ગોળીઓ સાથે. આદર્શ રીતે, ઊભી ટૅબ્સ માટે, તમારે aria-orientation="vertical"
ટૅબ સૂચિ કન્ટેનરમાં પણ ઉમેરવું જોઈએ.
આ અમુક પ્લેસહોલ્ડર સામગ્રી છે જે હોમ ટેબની સંબંધિત સામગ્રી છે. બીજા ટેબ પર ક્લિક કરવાથી આની દૃશ્યતા આગામી માટે ટૉગલ થઈ જશે. ટેબ JavaScript સામગ્રીની દૃશ્યતા અને સ્ટાઇલને નિયંત્રિત કરવા માટે વર્ગોને સ્વેપ કરે છે. તમે તેનો ઉપયોગ ટેબ્સ, ગોળીઓ અને અન્ય કોઈપણ .nav
સંચાલિત નેવિગેશન સાથે કરી શકો છો.
This is some placeholder content the Profile tab's associated content. Clicking another tab will toggle the visibility of this one for the next. The tab JavaScript swaps classes to control the content visibility and styling. You can use it with tabs, pills, and any other .nav
-powered navigation.
This is some placeholder content the Disabled tab's associated content.
This is some placeholder content the Messages tab's associated content. Clicking another tab will toggle the visibility of this one for the next. The tab JavaScript swaps classes to control the content visibility and styling. You can use it with tabs, pills, and any other .nav
-powered navigation.
This is some placeholder content the Settings tab's associated content. Clicking another tab will toggle the visibility of this one for the next. The tab JavaScript swaps classes to control the content visibility and styling. You can use it with tabs, pills, and any other .nav
-powered navigation.
<div class="d-flex align-items-start">
<div class="nav flex-column nav-pills me-3" id="v-pills-tab" role="tablist" aria-orientation="vertical">
<button class="nav-link active" id="v-pills-home-tab" data-bs-toggle="pill" data-bs-target="#v-pills-home" type="button" role="tab" aria-controls="v-pills-home" aria-selected="true">Home</button>
<button class="nav-link" id="v-pills-profile-tab" data-bs-toggle="pill" data-bs-target="#v-pills-profile" type="button" role="tab" aria-controls="v-pills-profile" aria-selected="false">Profile</button>
<button class="nav-link" id="v-pills-disabled-tab" data-bs-toggle="pill" data-bs-target="#v-pills-disabled" type="button" role="tab" aria-controls="v-pills-disabled" aria-selected="false" disabled>Disabled</button>
<button class="nav-link" id="v-pills-messages-tab" data-bs-toggle="pill" data-bs-target="#v-pills-messages" type="button" role="tab" aria-controls="v-pills-messages" aria-selected="false">Messages</button>
<button class="nav-link" id="v-pills-settings-tab" data-bs-toggle="pill" data-bs-target="#v-pills-settings" type="button" role="tab" aria-controls="v-pills-settings" aria-selected="false">Settings</button>
</div>
<div class="tab-content" id="v-pills-tabContent">
<div class="tab-pane fade show active" id="v-pills-home" role="tabpanel" aria-labelledby="v-pills-home-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="v-pills-profile" role="tabpanel" aria-labelledby="v-pills-profile-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="v-pills-disabled" role="tabpanel" aria-labelledby="v-pills-disabled-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="v-pills-messages" role="tabpanel" aria-labelledby="v-pills-messages-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="v-pills-settings" role="tabpanel" aria-labelledby="v-pills-settings-tab" tabindex="0">...</div>
</div>
</div>
ઉપલ્બધતા
ARIA ઓથરિંગ પ્રેક્ટિસ માર્ગદર્શિકા ટૅબ પેટર્નમાં વર્ણવ્યા મુજબ ડાયનેમિક ટૅબ કરેલ ઇન્ટરફેસને સહાયક તકનીકો (જેમ કે સ્ક્રીન રીડર્સ)ના વપરાશકર્તાઓને તેમની રચના, કાર્યક્ષમતા અને વર્તમાન સ્થિતિ જણાવવા માટે role="tablist"
, role="tab"
, role="tabpanel"
, અને વધારાના લક્ષણોની જરૂર પડે છે. aria-
શ્રેષ્ઠ પ્રથા તરીકે, અમે ટેબ માટે ઘટકોનો ઉપયોગ કરવાની ભલામણ કરીએ છીએ <button>
, કારણ કે આ એવા નિયંત્રણો છે જે ગતિશીલ પરિવર્તનને ટ્રિગર કરે છે, કોઈ નવા પૃષ્ઠ અથવા સ્થાન પર નેવિગેટ કરતી લિંક્સને બદલે.
ARIA ઓથરિંગ પ્રેક્ટિસ પેટર્નની અનુરૂપ, માત્ર હાલમાં સક્રિય ટેબ જ કીબોર્ડ ફોકસ મેળવે છે. જ્યારે JavaScript પ્લગઇન પ્રારંભ થાય છે, ત્યારે તે tabindex="-1"
તમામ નિષ્ક્રિય ટેબ નિયંત્રણો પર સેટ થશે. એકવાર વર્તમાનમાં સક્રિય ટેબ પર ફોકસ થઈ જાય તે પછી, કર્સર કીઓ પહેલાની/આગલી ટેબને સક્રિય કરે છે, પ્લગઇન તે મુજબ રોવિંગનેtabindex
બદલે છે . જો કે, નોંધ લો કે જ્યારે કર્સર કી ક્રિયાપ્રતિક્રિયાઓની વાત આવે છે ત્યારે JavaScript પ્લગઇન આડી અને ઊભી ટેબ સૂચિઓ વચ્ચે ભેદ પાડતું નથી: ટેબ સૂચિના ઓરિએન્ટેશનને ધ્યાનમાં લીધા વિના, ઉપર અને ડાબા બંને કર્સર પાછલા ટેબ પર જાય છે, અને નીચે અને જમણે કર્સર પર જાય છે. આગામી ટેબ.
tabindex="0"
JavaScript પ્લગઇન આ પાસાને હેન્ડલ કરવાનો પ્રયાસ કરતું નથી—જ્યાં યોગ્ય હોય, તમારે તમારા માર્કઅપમાં
ઉમેરીને સ્પષ્ટપણે તમારી ટેબ પેનલ્સને ફોકસેબલ બનાવવાની જરૂર પડશે
.ડેટા એટ્રિબ્યુટ્સનો ઉપયોગ કરીને
તમે કોઈ પણ જાવાસ્ક્રિપ્ટ લખ્યા વિના ટેબ અથવા પિલ નેવિગેશનને ફક્ત સ્પષ્ટ કરીને data-bs-toggle="tab"
અથવા data-bs-toggle="pill"
તત્વ પર સક્રિય કરી શકો છો. .nav-tabs
પર અથવા પર આ ડેટા વિશેષતાઓનો ઉપયોગ કરો .nav-pills
.
<!-- Nav tabs -->
<ul class="nav nav-tabs" id="myTab" role="tablist">
<li class="nav-item" role="presentation">
<button class="nav-link active" id="home-tab" data-bs-toggle="tab" data-bs-target="#home" type="button" role="tab" aria-controls="home" aria-selected="true">Home</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="profile-tab" data-bs-toggle="tab" data-bs-target="#profile" type="button" role="tab" aria-controls="profile" aria-selected="false">Profile</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="messages-tab" data-bs-toggle="tab" data-bs-target="#messages" type="button" role="tab" aria-controls="messages" aria-selected="false">Messages</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="settings-tab" data-bs-toggle="tab" data-bs-target="#settings" type="button" role="tab" aria-controls="settings" aria-selected="false">Settings</button>
</li>
</ul>
<!-- Tab panes -->
<div class="tab-content">
<div class="tab-pane active" id="home" role="tabpanel" aria-labelledby="home-tab" tabindex="0">...</div>
<div class="tab-pane" id="profile" role="tabpanel" aria-labelledby="profile-tab" tabindex="0">...</div>
<div class="tab-pane" id="messages" role="tabpanel" aria-labelledby="messages-tab" tabindex="0">...</div>
<div class="tab-pane" id="settings" role="tabpanel" aria-labelledby="settings-tab" tabindex="0">...</div>
</div>
JavaScript દ્વારા
જાવાસ્ક્રિપ્ટ દ્વારા ટેબેબલ ટેબ્સને સક્ષમ કરો (દરેક ટેબને વ્યક્તિગત રીતે સક્રિય કરવાની જરૂર છે):
const triggerTabList = document.querySelectorAll('#myTab button')
triggerTabList.forEach(triggerEl => {
const tabTrigger = new bootstrap.Tab(triggerEl)
triggerEl.addEventListener('click', event => {
event.preventDefault()
tabTrigger.show()
})
})
તમે વ્યક્તિગત ટેબને ઘણી રીતે સક્રિય કરી શકો છો:
const triggerEl = document.querySelector('#myTab button[data-bs-target="#profile"]')
bootstrap.Tab.getInstance(triggerEl).show() // Select tab by name
const triggerFirstTabEl = document.querySelector('#myTab li:first-child button')
bootstrap.Tab.getInstance(triggerFirstTabEl).show() // Select first tab
ફેડ અસર
ટૅબ્સને ફેડ ઇન કરવા માટે, .fade
દરેકમાં ઉમેરો .tab-pane
. પ્રથમ ટેબ ફલકમાં પણ .show
પ્રારંભિક સામગ્રી દૃશ્યમાન હોવી આવશ્યક છે.
<div class="tab-content">
<div class="tab-pane fade show active" id="home" role="tabpanel" aria-labelledby="home-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="profile" role="tabpanel" aria-labelledby="profile-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="messages" role="tabpanel" aria-labelledby="messages-tab" tabindex="0">...</div>
<div class="tab-pane fade" id="settings" role="tabpanel" aria-labelledby="settings-tab" tabindex="0">...</div>
</div>
પદ્ધતિઓ
અસુમેળ પદ્ધતિઓ અને સંક્રમણો
બધી API પદ્ધતિઓ અસુમેળ છે અને સંક્રમણ શરૂ કરે છે . સંક્રમણ શરૂ થતાંની સાથે જ તેઓ કૉલર પાસે પાછા ફરે છે પરંતુ તે સમાપ્ત થાય તે પહેલાં . વધુમાં, સંક્રમણ ઘટક પર પદ્ધતિ કૉલ અવગણવામાં આવશે .
તમારી સામગ્રીને ટેબ ઘટક તરીકે સક્રિય કરે છે.
તમે કન્સ્ટ્રક્ટર સાથે ટેબ દાખલો બનાવી શકો છો, ઉદાહરણ તરીકે:
const bsTab = new bootstrap.Tab('#myTab')
પદ્ધતિ | વર્ણન |
---|---|
dispose |
તત્વના ટેબનો નાશ કરે છે. |
getInstance |
સ્ટેટિક મેથડ જે તમને DOM એલિમેન્ટ સાથે સંકળાયેલ ટેબ ઇન્સ્ટન્સ મેળવવા માટે પરવાનગી આપે છે, તમે તેનો આ રીતે ઉપયોગ કરી શકો છો: bootstrap.Tab.getInstance(element) . |
getOrCreateInstance |
સ્ટેટિક મેથડ જે DOM ઘટક સાથે સંકળાયેલ ટેબ ઇન્સ્ટન્સ પરત કરે છે અથવા જો તે આરંભ ન થયું હોય તો નવું બનાવો. તમે તેનો આ રીતે ઉપયોગ કરી શકો છો: bootstrap.Tab.getOrCreateInstance(element) . |
show |
આપેલ ટેબ પસંદ કરે છે અને તેની સંલગ્ન તકતી બતાવે છે. કોઈપણ અન્ય ટેબ કે જે અગાઉ પસંદ કરવામાં આવી હતી તે નાપસંદ થઈ જાય છે અને તેની સાથે સંકળાયેલ ફલક છુપાયેલ છે. ટેબ પેન વાસ્તવમાં બતાવવામાં આવે તે પહેલાં કૉલર પર પાછા ફરે છે (એટલે કે shown.bs.tab ઇવેન્ટ થાય તે પહેલાં). |
ઘટનાઓ
નવી ટેબ બતાવતી વખતે, ઇવેન્ટ્સ નીચેના ક્રમમાં ફાયર થાય છે:
hide.bs.tab
(વર્તમાન સક્રિય ટેબ પર)show.bs.tab
(બતાવવાના ટેબ પર)hidden.bs.tab
(અગાઉના સક્રિય ટૅબ પર,hide.bs.tab
ઇવેન્ટની જેમ જ)shown.bs.tab
(નવા-સક્રિય-હમણાં-બતાવેલ ટેબ પર,show.bs.tab
ઇવેન્ટની જેમ જ)
જો કોઈ ટેબ પહેલાથી જ સક્રિય ન હોય, તો પછી hide.bs.tab
અને hidden.bs.tab
ઇવેન્ટ્સને ફાયર કરવામાં આવશે નહીં.
ઇવેન્ટનો પ્રકાર | વર્ણન |
---|---|
hide.bs.tab |
જ્યારે નવી ટેબ બતાવવાની હોય ત્યારે આ ઇવેન્ટ ફાયર થાય છે (અને આમ અગાઉની સક્રિય ટેબ છુપાવવાની હોય છે). અનુક્રમે વર્તમાન સક્રિય ટેબ અને નવા ટૂંક સમયમાં સક્રિય થનારી ટેબનો ઉપયોગ કરો event.target અને લક્ષ્યાંકિત કરો.event.relatedTarget |
hidden.bs.tab |
નવી ટેબ દર્શાવ્યા પછી આ ઇવેન્ટ ફાયર થાય છે (અને આમ અગાઉની સક્રિય ટેબ છુપાયેલ છે). અનુક્રમે અગાઉના સક્રિય ટેબ અને નવા સક્રિય ટેબનો ઉપયોગ કરો event.target અને તેને લક્ષ્ય બનાવો.event.relatedTarget |
show.bs.tab |
આ ઇવેન્ટ ટેબ શો પર ફાયર થાય છે, પરંતુ નવી ટેબ બતાવવામાં આવે તે પહેલાં. અનુક્રમે સક્રિય ટેબ અને અગાઉના સક્રિય ટેબ (જો ઉપલબ્ધ હોય તો) નો ઉપયોગ કરો event.target અને તેને લક્ષ્ય બનાવો.event.relatedTarget |
shown.bs.tab |
આ ઇવેન્ટ ટેબ બતાવ્યા પછી ટેબ શો પર ફાયર થાય છે. અનુક્રમે સક્રિય ટેબ અને અગાઉના સક્રિય ટેબ (જો ઉપલબ્ધ હોય તો) નો ઉપયોગ કરો event.target અને તેને લક્ષ્ય બનાવો.event.relatedTarget |
const tabEl = document.querySelector('button[data-bs-toggle="tab"]')
tabEl.addEventListener('shown.bs.tab', event => {
event.target // newly activated tab
event.relatedTarget // previous active tab
})