नवबार
बूटस्ट्रॅपच्या शक्तिशाली, प्रतिसादात्मक नेव्हिगेशन शीर्षलेख, नॅव्हबारसाठी दस्तऐवजीकरण आणि उदाहरणे. आमच्या संकुचित प्लगइनसाठी समर्थनासह ब्रँडिंग, नेव्हिगेशन आणि अधिकसाठी समर्थन समाविष्ट आहे.
हे कसे कार्य करते
navbar सह प्रारंभ करण्यापूर्वी तुम्हाला काय माहित असणे आवश्यक आहे ते येथे आहे:
- रिस्पॉन्सिव्ह कोलॅप्सिंग आणि
.navbar
कलर स्कीम क्लासेससाठी नवबारांना रॅपिंगची आवश्यकता असते ..navbar-expand{-sm|-md|-lg|-xl|-xxl}
- Navbars आणि त्यांची सामग्री डीफॉल्टनुसार द्रव असतात. वेगवेगळ्या प्रकारे त्यांची क्षैतिज रुंदी मर्यादित करण्यासाठी कंटेनर बदला .
- navbars मध्ये अंतर आणि संरेखन नियंत्रित करण्यासाठी आमचे अंतर आणि फ्लेक्स उपयुक्तता वर्ग वापरा.
- नवबार डीफॉल्टनुस��र प्रतिसाद देणारे असतात, परंतु ते बदलण्यासाठी तुम्ही त्यांना सहजपणे बदलू शकता. प्रतिसादात्मक वर्तन आमच्या संकुचित JavaScript प्लगइनवर अवलंबून असते.
- घटक वापरून प्रवेशयोग्यता सुनिश्चित करा
<nav>
किंवा, अधिक सामान्य घटक वापरत असल्यास , सहाय्यक तंत्रज्ञानाच्या वापरकर्त्यांसाठी एक महत्त्वाचा प्रदेश म्हणून स्पष्टपणे ओळखण्यासाठी प्रत्येक नॅव्हबारमध्ये<div>
एक जोडा .role="navigation"
aria-current="page"
वर्तमान पृष्ठासाठी किंवाaria-current="true"
सेटमधील वर्तमान आयटमसाठी वापरून वर्तमान आयटम सूचित करा .
prefers-reduced-motion
मीडिया क्वेरीवर अवलंबून असतो. आमच्या प्रवेशयोग्यता दस्तऐवजीकरणाचा कमी गती विभाग पहा
.
समर्थित सामग्री
मूठभर उप-घटकांसाठी नवबार अंगभूत समर्थनासह येतात. आवश्यकतेनुसार खालीलपैकी निवडा:
.navbar-brand
तुमच्या कंपनीसाठी, उत्पादनासाठी किंवा प्रकल्पाच्या नावासाठी..navbar-nav
पूर्ण-उंची आणि हलके नेव्हिगेशनसाठी (ड्रॉपडाउनसाठी समर्थनासह)..navbar-toggler
आमच्या संकुचित प्लगइन आणि इतर नेव्हिगेशन टॉगल वर्तनासह वापरण्यासाठी.- कोणत्याही फॉर्म नियंत्रणे आणि कृतींसाठी फ्लेक्स आणि स्पेसिंग उपयुक्तता.
.navbar-text
मजकूराच्या अनुलंब केंद्रीत स्ट्रिंग जोडण्यासाठी..collapse.navbar-collapse
पॅरेंट ब्रेकपॉइंटद्वारे navbar सामग्री गटबद्ध करण्यासाठी आणि लपवण्यासाठी..navbar-scroll
सेट करण्यासाठी पर्यायी जोडाmax-height
आणि विस्तारित नॅव्हबार सामग्री स्क्रोल करा .
प्रतिसादात्मक प्रकाश-थीम असलेल्या नॅव्हबारमध्ये समाविष्ट केलेल्या सर्व उप-घटकांचे एक उदाहरण येथे आहे जे lg
(मोठ्या) ब्रेकपॉइंटवर आपोआप कोसळते.
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarSupportedContent">
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Dropdown
</a>
<ul class="dropdown-menu" aria-labelledby="navbarDropdown">
<li><a class="dropdown-item" href="#">Action</a></li>
<li><a class="dropdown-item" href="#">Another action</a></li>
<li><hr class="dropdown-divider"></li>
<li><a class="dropdown-item" href="#">Something else here</a></li>
</ul>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
<form class="d-flex">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</div>
</nav>
हे उदाहरण पार्श्वभूमी ( bg-light
) आणि अंतर ( my-2
, my-lg-0
, me-sm-0
, my-sm-0
) उपयोगिता वर्ग वापरते.
ब्रँड
.navbar-brand
बहुतेक घटकांवर लागू केले जाऊ शकते, परंतु अँकर सर्वोत्तम कार्य करते, कारण काही घटकांना उपयुक्तता वर्ग किंवा सानुकूल शैली आवश्यक असू शकतात .
मजकूर
.navbar-brand
वर्गातील घटकामध्ये तुमचा मजकूर जोडा .
<!-- As a link -->
<nav class="navbar navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
</div>
</nav>
<!-- As a heading -->
<nav class="navbar navbar-light bg-light">
<div class="container-fluid">
<span class="navbar-brand mb-0 h1">Navbar</span>
</div>
</nav>
प्रतिमा
तुम्ही मधील मजकूर बदलू .navbar-brand
शकता <img>
.
<nav class="navbar navbar-light bg-light">
<div class="container">
<a class="navbar-brand" href="#">
<img src="/docs/5.1/assets/brand/bootstrap-logo.svg" alt="" width="30" height="24">
</a>
</div>
</nav>
प्रतिमा आणि मजकूर
एकाच वेळी प्रतिमा आणि मजकूर जोडण्यासाठी तुम्ही काही अतिरिक्त उपयुक्तता देखील वापरू शकता. ची जोडणी लक्षात ठेवा .d-inline-block
आणि .align-text-top
वर <img>
.
<nav class="navbar navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">
<img src="/docs/5.1/assets/brand/bootstrap-logo.svg" alt="" width="30" height="24" class="d-inline-block align-text-top">
Bootstrap
</a>
</div>
</nav>
नव
नवबार नेव्हिगेशन लिंक .nav
त्यांच्या स्वतःच्या सुधारक वर्गासह आमच्या पर्यायांवर तयार करतात आणि योग्य प्रतिसादात्मक शैलीसाठी टॉगलर वर्ग वापरणे आवश्यक आहे. तुमची navbar सामग्री सुरक्षितपणे संरेखित ठेवण्यासाठी नॅव्हबारमधील नेव्हिगेशन देखील शक्य तितकी क्षैतिज जागा व्यापेल .
वर्तमान पृष्ठ सूचित करण्यासाठी .active
वर्ग जोडा ..nav-link
aria-current
कृपया लक्षात घ्या की तुम्ही सक्रिय वर विशेषता देखील जोडली पाहिजे .nav-link
.
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarNav">
<ul class="navbar-nav">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Features</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Pricing</a>
</li>
<li class="nav-item">
<a class="nav-link disabled">Disabled</a>
</li>
</ul>
</div>
</div>
</nav>
आणि आम्ही आमच्या एनएव्हीसाठी वर्ग वापरत असल्यामुळे, तुम्हाला आवडत असल्यास तुम्ही सूची-आधारित दृष्टिकोन पूर्णपणे टाळू शकता.
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarNavAltMarkup" aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
<div class="navbar-nav">
<a class="nav-link active" aria-current="page" href="#">Home</a>
<a class="nav-link" href="#">Features</a>
<a class="nav-link" href="#">Pricing</a>
<a class="nav-link disabled">Disabled</a>
</div>
</div>
</div>
</nav>
तुम्ही तुमच्या navbar मध्ये ड्रॉपडाउन देखील वापरू शकता. ड्रॉपडाउन मेनूमध्ये पोझिशनिंगसाठी रॅपिंग घटक आवश्यक आहेत, म्हणून खाली दर्शविल्याप्रमाणे स्वतंत्र .nav-item
आणि नेस्टेड घटक वापरण्याची खात्री करा ..nav-link
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarNavDropdown" aria-controls="navbarNavDropdown" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarNavDropdown">
<ul class="navbar-nav">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Features</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Pricing</a>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdownMenuLink" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Dropdown link
</a>
<ul class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
<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>
</ul>
</li>
</ul>
</div>
</div>
</nav>
फॉर्म
navbar मध्ये विविध फॉर्म नियंत्रणे आणि घटक ठेवा:
<nav class="navbar navbar-light bg-light">
<div class="container-fluid">
<form class="d-flex">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</nav>
फ्लेक्स लेआउट वापरण्याचे तात्काळ मूल घटक .navbar
आणि ते डीफॉल्ट असेल justify-content: space-between
. हे वर्तन समायोजित करण्यासाठी आवश्यकतेनुसार अतिरिक्त फ्लेक्स उपयुक्तता ��ापरा .
<nav class="navbar navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand">Navbar</a>
<form class="d-flex">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</nav>
इनपुट गट देखील कार्य करतात. <form>
जर तुमचा नॅव्हबार संपूर्ण फॉर्म असेल किंवा बहुतेक फॉर्म असेल, तर तुम्ही घटक कंटेनर म्हणून वापरू शकता आणि काही HTML जतन करू शकता.
<nav class="navbar navbar-light bg-light">
<form class="container-fluid">
<div class="input-group">
<span class="input-group-text" id="basic-addon1">@</span>
<input type="text" class="form-control" placeholder="Username" aria-label="Username" aria-describedby="basic-addon1">
</div>
</form>
</nav>
या navbar फॉर्मचा भाग म्हणून विविध बटणे देखील समर्थित आहेत. हे देखील एक उत्तम स्मरणपत्र आहे की उभ्या संरेखन उपयुक्तता वेगवेगळ्या आकाराच्या घटकांना संरेखित करण्यासाठी वापरल्या जाऊ शकतात.
<nav class="navbar navbar-light bg-light">
<form class="container-fluid justify-content-start">
<button class="btn btn-outline-success me-2" type="button">Main button</button>
<button class="btn btn-sm btn-outline-secondary" type="button">Smaller button</button>
</form>
</nav>
मजकूर
च्या मदतीने नवबारमध्ये मजकूराचे बिट असू शकतात .navbar-text
. हा वर्ग मजकूराच्या स्ट्रिंगसाठी अनुलंब संरेखन आणि क्षैतिज अंतर समायोजित करतो.
<nav class="navbar navbar-light bg-light">
<div class="container-fluid">
<span class="navbar-text">
Navbar text with an inline element
</span>
</div>
</nav>
आवश्यकतेनुसार इतर घटक आणि उपयुक्तता मिसळा आणि जुळवा.
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar w/ text</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarText" aria-controls="navbarText" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarText">
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Features</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Pricing</a>
</li>
</ul>
<span class="navbar-text">
Navbar text with an inline element
</span>
</div>
</div>
</nav>
रंग योजना
background-color
थीमिंग क्लासेस आणि युटिलिटीजच्या संयोजनामुळे नवबारची थीमिंग करणे कधीही सोपे नव्हते . .navbar-light
हलक्या पार्श्वभूमी रंगांसह वापरण्यासाठी किंवा .navbar-dark
गडद पार्श्वभूमी रंगांसाठी निवडा . त्यानंतर, .bg-*
युटिलिटीजसह सानुकूलित करा.
<nav class="navbar navbar-dark bg-dark">
<!-- Navbar content -->
</nav>
<nav class="navbar navbar-dark bg-primary">
<!-- Navbar content -->
</nav>
<nav class="navbar navbar-light" style="background-color: #e3f2fd;">
<!-- Navbar content -->
</nav>
कंटेनर
हे आवश्यक नसले तरी, आपण .container
पृष्ठावर मध्यभागी ठेवण्यासाठी नॅव्हबार गुंडाळू शकता-तरी लक्षात ठेवा की आतील कंटेनर अद्याप आवश्यक आहे. किंवा तुम्ही फिक्स्ड किंवा स्टॅटिक टॉप नॅव्हबारची.navbar
सामग्री फक्त मध्यभागी ठेवण्यासाठी आत कंटेनर जोडू शकता .
<div class="container">
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
</div>
</nav>
</div>
तुमच्या navbar मधील सामग्री किती विस्तृत आहे हे बदलण्यासाठी कोणतेही प्रतिसादात्मक कंटेनर वापरा.
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-md">
<a class="navbar-brand" href="#">Navbar</a>
</div>
</nav>
प्लेसमेंट
नॉन-स्टॅटिक पोझिशन्समध्ये नॅव्हबार ठेवण्यासाठी आमची पोझिशन युटिलिटी वापरा . शीर्षस्थानी स्थिर, तळाशी निश्चित केलेले किंवा शीर्षस्थानी चिकटलेले निवडा (पृष्ठ शीर्षस्थानी पोहोचेपर्यंत स्क्रोल करा, नंतर तिथेच राहा). निश्चित नॅव्हबार वापरतात position: fixed
, म्हणजे ते DOM च्या सामान्य प्रवाहापासून खेचले जातात आणि इतर घटकांसह ओव्हरलॅप टाळण्यासाठी त्यांना सानुकूल CSS (उदा. padding-top
वर ) आवश्यक असू शकते.<body>
.sticky-top
वापरतेposition: sticky
हे देखील लक्षात ठेवा , जे प्रत्येक ब्राउझरमध्ये पूर्णपणे समर्थित नाही .
<nav class="navbar navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Default</a>
</div>
</nav>
<nav class="navbar fixed-top navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Fixed top</a>
</div>
</nav>
<nav class="navbar fixed-bottom navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Fixed bottom</a>
</div>
</nav>
<nav class="navbar sticky-top navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Sticky top</a>
</div>
</nav>
स्क्रोलिंग
.navbar-nav-scroll
संकुचित नॅव्हबारच्या टॉगल करण्यायोग्य सामग्रीमध्ये अनुलंब स्क्रोलिंग सक्षम करण्यासाठी .navbar-nav
(किंवा इतर navbar उप-घटक) मध्ये जोडा . डीफॉल्टनुसार, स्क्रोलिंग (किंवा व्ह्यूपोर्ट उंचीच्या 75%) वर होते, परंतु तुम्ही ते स्थानिक CSS कस्टम गुणधर्म किंवा कस्टम शैलींसह 75vh
ओव्हरराइड करू शकता . --bs-navbar-height
मोठ्या व्ह्यूपोर्ट्सवर जेव्हा नॅव्हबारचा विस्तार केला जातो, तेव्हा सामग्री डीफॉल्ट नॅव्हबारमध्ये दिसते तशी दिसेल.
overflow
कृपया लक्षात ठेवा की हे वर्तन —when सेटिंग overflow-y: auto
(येथे सामग्री स्क्रोल करणे आवश्यक आहे) च्या संभाव्य दोषासह येते overflow-x
, auto
जे काही क्षैतिज सामग्री क्रॉप करेल.
इष्टतम अंतरासाठी काही अतिरिक्त मार्जिन युटिलिटिजसह, .navbar-nav-scroll
वापरून नॅव्हबारचे उदाहरण येथे आहे.style="--bs-scroll-height: 100px;"
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar scroll</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarScroll" aria-controls="navbarScroll" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarScroll">
<ul class="navbar-nav me-auto my-2 my-lg-0 navbar-nav-scroll" style="--bs-scroll-height: 100px;">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navbarScrollingDropdown" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Link
</a>
<ul class="dropdown-menu" aria-labelledby="navbarScrollingDropdown">
<li><a class="dropdown-item" href="#">Action</a></li>
<li><a class="dropdown-item" href="#">Another action</a></li>
<li><hr class="dropdown-divider"></li>
<li><a class="dropdown-item" href="#">Something else here</a></li>
</ul>
</li>
<li class="nav-item">
<a class="nav-link disabled">Link</a>
</li>
</ul>
<form class="d-flex">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</div>
</nav>
प्रतिसादात्मक आचरण
.navbar-toggler
नवबार , .navbar-collapse
, आणि वर्ग वापरू शकतात .navbar-expand{-sm|-md|-lg|-xl|-xxl}
ते निर्धारित करण्यासाठी त्यांची सामग्री बटणाच्या मागे कधी कोसळते. इतर उपयुक्ततांच्या संयोजनात, विशिष्ट घटक कधी दाखवायचे किंवा लपवायचे ते तुम्ही सहजपणे निवडू शकता.
कधीही कोलॅप्स न होणाऱ्या नवबारांसाठी, नवबारवर .navbar-expand
वर्ग जोडा. नेहमी संकुचित होणाऱ्या नवबारांसाठी, कोणताही .navbar-expand
वर्ग जोडू नका.
टॉगलर
नवबार टॉगलर्स डीफॉल्टनुसार डावीकडे संरेखित केले जातात, परंतु त्यांनी सारख्या भावी घटकाचे अनुसरण .navbar-brand
केल्यास, ते स्वयंचलितपणे अगदी उजवीकडे संरेखित केले जातील. तुमचा मार्कअप उलट केल्याने टॉगलरची नियुक्ती उलट होईल. खाली वेगवेगळ्या टॉगल शैलींची उदाहरणे आहेत.
सर्वात .navbar-brand
लहान ब्रेकपॉइंटवर दर्शविल्याशिवाय:
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarTogglerDemo01" aria-controls="navbarTogglerDemo01" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarTogglerDemo01">
<a class="navbar-brand" href="#">Hidden brand</a>
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</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>
<form class="d-flex">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</div>
</nav>
डावीकडे दर्शविलेल्या ब्रँड नावासह आणि उजवीकडे टॉगलरसह:
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarTogglerDemo02" aria-controls="navbarTogglerDemo02" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarTogglerDemo02">
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</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>
<form class="d-flex">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</div>
</nav>
डावीकडे टॉगलर आणि उजवीकडे ब्रँड नाव:
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<div class="container-fluid">
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarTogglerDemo03" aria-controls="navbarTogglerDemo03" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<a class="navbar-brand" href="#">Navbar</a>
<div class="collapse navbar-collapse" id="navbarTogglerDemo03">
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</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>
<form class="d-flex">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</div>
</nav>
बाह्य सामग्री
काहीवेळा तुम्ही संरचनेच्या बाहेर असलेल्या सामग्रीसाठी कंटेनर घटक ट्रिगर करण्यासाठी कोलॅप्स प्लगइन वापरू इच्छिता .navbar
. कारण आमचे प्लगइन वर id
आणि data-bs-target
जुळण्यावर कार्य करते, ते सहज केले जाते!
<div class="collapse" id="navbarToggleExternalContent">
<div class="bg-dark p-4">
<h5 class="text-white h4">Collapsed content</h5>
<span class="text-muted">Toggleable via the navbar brand.</span>
</div>
</div>
<nav class="navbar navbar-dark bg-dark">
<div class="container-fluid">
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarToggleExternalContent" aria-controls="navbarToggleExternalContent" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
</div>
</nav>
तुम्ही हे केल्यावर, कंटेनर उघडल्यावर फोकस प्रोग्रामेटिकरित्या हलवण्यासाठी आम्ही अतिरिक्त JavaScript समाविष्ट करण्याची शिफारस करतो. अन्यथा, कीबोर्ड वापरकर्त्यांना आणि सहाय्यक तंत्रज्ञानाच्या वापरकर्त्यांना नवीन प्रकट केलेली सामग्री शोधण्यात कठिण वेळ लागेल - विशेषतः जर उघडलेला कंटेनर दस्तऐवजाच्या संरचनेत टॉगलरच्या आधी आला असेल. आम्ही सामग्री कंटेनरच्याकडे aria-controls
निर्देश करून टॉगलरकडे विशेषता असल्याची खात्री करण्याची देखील शिफारस करतो . id
सैद्धांतिकदृष्ट्या, हे सहाय्यक तंत्रज्ञान वापरकर्त्यांना टॉगलरवरून ते नियंत्रित करत असलेल्या कंटेनरवर थेट जाण्यास अनुमती देते-परंतु यासाठी समर्थन सध्या खूपच खराब आहे.
ऑफकॅनव्हास
ऑफकॅनव्हास प्लगइनसह तुमचा विस्तार आणि कोलॅप्सिंग नॅव्हबार ऑफकॅनव्हास ड्रॉवरमध्ये बदला. आम्ही दोन्ही ऑफकॅनव्हास डीफॉल्ट शैली वाढवतो आणि .navbar-expand-*
डायनॅमिक आणि लवचिक नेव्हिगेशन साइडबार तयार करण्यासाठी आमचे वर्ग वापरतो.
खालील उदाहरणात, ऑफकॅनव्हास नॅव्हबार तयार करण्यासाठी जो नेहमी सर्व ब्रेकपॉइंट्सवर संकुचित केला जातो, .navbar-expand-*
वर्ग पूर्णपणे वगळा.
<nav class="navbar navbar-light bg-light fixed-top">
<div class="container-fluid">
<a class="navbar-brand" href="#">Offcanvas navbar</a>
<button class="navbar-toggler" type="button" data-bs-toggle="offcanvas" data-bs-target="#offcanvasNavbar" aria-controls="offcanvasNavbar">
<span class="navbar-toggler-icon"></span>
</button>
<div class="offcanvas offcanvas-end" tabindex="-1" id="offcanvasNavbar" aria-labelledby="offcanvasNavbarLabel">
<div class="offcanvas-header">
<h5 class="offcanvas-title" id="offcanvasNavbarLabel">Offcanvas</h5>
<button type="button" class="btn-close text-reset" data-bs-dismiss="offcanvas" aria-label="Close"></button>
</div>
<div class="offcanvas-body">
<ul class="navbar-nav justify-content-end flex-grow-1 pe-3">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="offcanvasNavbarDropdown" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Dropdown
</a>
<ul class="dropdown-menu" aria-labelledby="offcanvasNavbarDropdown">
<li><a class="dropdown-item" href="#">Action</a></li>
<li><a class="dropdown-item" href="#">Another action</a></li>
<li>
<hr class="dropdown-divider">
</li>
<li><a class="dropdown-item" href="#">Something else here</a></li>
</ul>
</li>
</ul>
<form class="d-flex">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</div>
</div>
</nav>
ऑफकॅनव्हास नॅव्हबार तयार करण्यासाठी जे विशिष्ट ब्रेकपॉइंटवर सामान्य नॅव्हबारमध्ये विस्तारित होते जसे की lg
, वापरा .navbar-expand-lg
.
<nav class="navbar navbar-light navbar-expand-lg bg-light fixed-top">
<a class="navbar-brand" href="#">Offcanvas navbar</a>
<button class="navbar-toggler" type="button" data-bs-toggle="offcanvas" data-bs-target="#navbarOffcanvasLg" aria-controls="navbarOffcanvasLg">
<span class="navbar-toggler-icon"></span>
</button>
<div class="offcanvas offcanvas-end" tabindex="-1" id="navbarOffcanvasLg" aria-labelledby="navbarOffcanvasLgLabel">
...
</div>
</nav>
सस
चल
$navbar-padding-y: $spacer * .5;
$navbar-padding-x: null;
$navbar-nav-link-padding-x: .5rem;
$navbar-brand-font-size: $font-size-lg;
// Compute the navbar-brand padding-y so the navbar-brand will have the same height as navbar-text and nav-link
$nav-link-height: $font-size-base * $line-height-base + $nav-link-padding-y * 2;
$navbar-brand-height: $navbar-brand-font-size * $line-height-base;
$navbar-brand-padding-y: ($nav-link-height - $navbar-brand-height) * .5;
$navbar-brand-margin-end: 1rem;
$navbar-toggler-padding-y: .25rem;
$navbar-toggler-padding-x: .75rem;
$navbar-toggler-font-size: $font-size-lg;
$navbar-toggler-border-radius: $btn-border-radius;
$navbar-toggler-focus-width: $btn-focus-width;
$navbar-toggler-transition: box-shadow .15s ease-in-out;
$navbar-dark-color: rgba($white, .55);
$navbar-dark-hover-color: rgba($white, .75);
$navbar-dark-active-color: $white;
$navbar-dark-disabled-color: rgba($white, .25);
$navbar-dark-toggler-icon-bg: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'><path stroke='#{$navbar-dark-color}' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/></svg>");
$navbar-dark-toggler-border-color: rgba($white, .1);
$navbar-light-color: rgba($black, .55);
$navbar-light-hover-color: rgba($black, .7);
$navbar-light-active-color: rgba($black, .9);
$navbar-light-disabled-color: rgba($black, .3);
$navbar-light-toggler-icon-bg: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'><path stroke='#{$navbar-light-color}' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/></svg>");
$navbar-light-toggler-border-color: rgba($black, .1);
$navbar-light-brand-color: $navbar-light-active-color;
$navbar-light-brand-hover-color: $navbar-light-active-color;
$navbar-dark-brand-color: $navbar-dark-active-color;
$navbar-dark-brand-hover-color: $navbar-dark-active-color;
पळवाट
रिस्पॉन्सिव्ह नॅव्हबार विस्तार/संकुचित वर्ग (उदा., .navbar-expand-lg
) नकाशासह एकत्रित केले जातात $breakpoints
आणि लूपद्वारे व्युत्पन्न केले जातात scss/_navbar.scss
.
// Generate series of `.navbar-expand-*` responsive classes for configuring
// where your navbar collapses.
.navbar-expand {
@each $breakpoint in map-keys($grid-breakpoints) {
$next: breakpoint-next($breakpoint, $grid-breakpoints);
$infix: breakpoint-infix($next, $grid-breakpoints);
// stylelint-disable-next-line scss/selector-no-union-class-name
&#{$infix} {
@include media-breakpoint-up($next) {
flex-wrap: nowrap;
justify-content: flex-start;
.navbar-nav {
flex-direction: row;
.dropdown-menu {
position: absolute;
}
.nav-link {
padding-right: $navbar-nav-link-padding-x;
padding-left: $navbar-nav-link-padding-x;
}
}
.navbar-nav-scroll {
overflow: visible;
}
.navbar-collapse {
display: flex !important; // stylelint-disable-line declaration-no-important
flex-basis: auto;
}
.navbar-toggler {
display: none;
}
.offcanvas-header {
display: none;
}
.offcanvas {
position: inherit;
bottom: 0;
z-index: 1000;
flex-grow: 1;
visibility: visible !important; // stylelint-disable-line declaration-no-important
background-color: transparent;
border-right: 0;
border-left: 0;
@include transition(none);
transform: none;
}
.offcanvas-top,
.offcanvas-bottom {
height: auto;
border-top: 0;
border-bottom: 0;
}
.offcanvas-body {
display: flex;
flex-grow: 0;
padding: 0;
overflow-y: visible;
}
}
}
}
}