नवबार
बुटस्ट्र्यापको शक्तिशाली, उत्तरदायी नेभिगेसन हेडर, नेभबारका लागि दस्तावेज र उदाहरणहरू। हाम्रो पतन प्लगइनको लागि समर्थन सहित ब्रान्डिङ, नेभिगेसन, र थपको लागि समर्थन समावेश गर्दछ।
यसले कसरी काम गर्छ
नवबारको साथ सुरू गर्नु अघि तपाईंले जान्न आवश्यक पर्ने कुराहरू यहाँ छन्:
- नवबारहरूलाई प्रतिक्रियाशील पतन र रङ योजना वर्गहरूको
.navbar
लागि र्यापिङ चाहिन्छ ।.navbar-expand{-sm|-md|-lg|-xl|-xxl}
- Navbars र तिनीहरूका सामग्रीहरू पूर्वनिर्धारित रूपमा तरल हुन्छन्। तिनीहरूको तेर्सो चौडाइलाई विभिन्न तरिकामा सीमित गर्न कन्टेनर परिवर्तन गर्नुहोस् ।
- navbars भित्र स्पेसिङ र पङ्क्तिबद्धता नियन्त्रण गर्न हाम्रो स्पेसिङ र फ्लेक्स उपयोगिता कक्षाहरू प्रयोग गर्नुहोस्।
- Navbars पूर्वनिर्धारित रूपमा उत्तरदायी छन्, तर तपाईं सजिलै परिवर्तन गर्न तिनीहरूलाई परिमार्जन गर्न सक्नुहुन्छ। उत्तरदायी व्यवहार हाम्रो संक्षिप्त JavaScript प्लगइनमा निर्भर गर्दछ।
- एक तत्व प्रयोग गरेर पहुँच सुनिश्चित गर्नुहोस्
<nav>
वा, यदि थप जेनेरिक तत्व जस्तै a को प्रयोग गरी , प्रत्येक navbar मा<div>
एक थप्नुहोस्role="navigation"
यसलाई सहायक प्रविधिहरूको प्रयोगकर्ताहरूको लागि ल्यान्डमार्क क्षेत्रको रूपमा स्पष्ट रूपमा पहिचान गर्न। aria-current="page"
हालको पृष्ठकोaria-current="true"
लागि वा सेटमा हालको वस्तुको लागि प्रयोग गरेर हालको वस्तुलाई संकेत गर्नुहोस् ।- v5.2.0 मा नयाँ: नेभबारहरू
.navbar
आधार वर्गमा स्कोप गरिएका CSS चरहरूसँग थिममा आधारित हुन सक्छन्।.navbar-light
हटाइएको छ र.navbar-dark
थप शैलीहरू थप्नुको सट्टा CSS चरहरू ओभरराइड गर्न पुन: लेखिएको छ।
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 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="#" role="button" data-bs-toggle="dropdown" 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><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" role="search">
<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
) र स्पेसिङ ( me-auto
, mb-2
, mb-lg-0
, me-2
) उपयोगिता वर्गहरू प्रयोग गर्दछ।
ब्रान्ड
.navbar-brand
धेरै तत्वहरूमा लागू गर्न सकिन्छ, तर एङ्करले राम्रो काम गर्दछ, किनकि केही तत्वहरूलाई उपयोगिता वर्ग वा अनुकूलन शैलीहरू आवश्यक हुन सक्छ ।
पाठ
.navbar-brand
कक्षाको साथ एक तत्व भित्र आफ्नो पाठ थप्नुहोस् ।
<!-- As a link -->
<nav class="navbar bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
</div>
</nav>
<!-- As a heading -->
<nav class="navbar bg-light">
<div class="container-fluid">
<span class="navbar-brand mb-0 h1">Navbar</span>
</div>
</nav>
छवि
तपाईं भित्रको पाठलाई एउटासँग बदल्न .navbar-brand
सक्नुहुन्छ <img>
।
<nav class="navbar bg-light">
<div class="container">
<a class="navbar-brand" href="#">
<img src="/docs/5.2/assets/brand/bootstrap-logo.svg" alt="Bootstrap" width="30" height="24">
</a>
</div>
</nav>
छवि र पाठ
तपाईं एकै समयमा छवि र पाठ थप्न केही अतिरिक्त उपयोगिताहरू पनि प्रयोग गर्न सक्नुहुन्छ। को थप .d-inline-block
र .align-text-top
मा ध्यान दिनुहोस् <img>
।
<nav class="navbar bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">
<img src="/docs/5.2/assets/brand/bootstrap-logo.svg" alt="Logo" width="30" height="24" class="d-inline-block align-text-top">
Bootstrap
</a>
</div>
</nav>
Nav
Navbar नेभिगेसन लिङ्कहरू .nav
तिनीहरूको आफ्नै परिमार्जक वर्गको साथ हाम्रा विकल्पहरूमा निर्माण हुन्छन् र उचित प्रतिक्रियाशील शैलीको लागि टगलर वर्गहरूको प्रयोग आवश्यक पर्दछ। तपाईंको नेभबार सामग्रीहरू सुरक्षित रूपमा पङ्क्तिबद्ध राख्नको लागि नेभबारहरूमा नेभिगेसनले सकेसम्म धेरै तेर्सो ठाउँ ओगटेको छ ।
हालको पृष्ठ संकेत गर्न .active
कक्षा थप्नुहोस् ।.nav-link
कृपया ध्यान दिनुहोस् कि तपाईंले सक्रियमा aria-current
विशेषता पनि थप्नुपर्छ .nav-link
।
<nav class="navbar navbar-expand-lg 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>
र किनभने हामी हाम्रो navs को लागि कक्षाहरू प्रयोग गर्दछौं, यदि तपाई चाहनुहुन्छ भने तपाईले सूचीमा आधारित दृष्टिकोणलाई पूर्ण रूपमा बेवास्ता गर्न सक्नुहुन्छ।
<nav class="navbar navbar-expand-lg 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>
तपाईं आफ्नो नेभबारमा ड्रपडाउनहरू पनि प्रयोग गर्न सक्नुहुन्छ। ड्रपडाउन मेनुहरूलाई स्थितिको लागि र्यापिङ तत्व चाहिन्छ, त्यसैले तल देखाइए अनुसार अलग .nav-item
र नेस्टेड तत्वहरू प्रयोग गर्न निश्चित हुनुहोस्।.nav-link
<nav class="navbar navbar-expand-lg 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="#" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Dropdown link
</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>
</ul>
</li>
</ul>
</div>
</div>
</nav>
फारमहरू
नेभबार भित्र विभिन्न फारम नियन्त्रण र कम्पोनेन्टहरू राख्नुहोस्:
<nav class="navbar bg-light">
<div class="container-fluid">
<form class="d-flex" role="search">
<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 bg-light">
<div class="container-fluid">
<a class="navbar-brand">Navbar</a>
<form class="d-flex" role="search">
<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 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 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>
पाठ
Navbars को मद्दतले पाठको बिटहरू समावेश हुन सक्छ .navbar-text
। यो वर्गले पाठको स्ट्रिङका लागि ठाडो पङ्क्तिबद्धता र तेर्सो स्पेसिङ समायोजन गर्छ।
<nav class="navbar 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 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>
रङ योजनाहरू
.navbar-light
गरिएको छ। CSS चरहरू "प्रकाश" उपस्थितिमा पूर्वनिर्धारित, मा लागू गरिन्छ
.navbar
, र ओभरराइड गर्न सकिन्छ
.navbar-dark
।
बुटस्ट्र्यापको Sass र CSS चरहरूको संयोजनको लागि Navbar विषयवस्तुहरू पहिले भन्दा सजिलो छन्। हल्का पृष्ठभूमि रङहरूसँग प्रयोगको लागि पूर्वनिर्धारित हाम्रो "लाइट नेभबार" हो, तर तपाइँ .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" style="background-color: #e3f2fd;">
<!-- Navbar content -->
</nav>
कन्टेनरहरू
.container
यद्यपि यो आवश्यक छैन, तपाइँ पृष्ठमा केन्द्रित गर्नको लागि एउटा नेभबारलाई लपेट्न सक्नुहुन्छ - यद्यपि नोट गर्नुहोस् कि भित्री कन्टेनर अझै आवश्यक छ। वा तपाईले निश्चित वा स्थिर शीर्ष नेभबारको.navbar
सामग्रीलाई केन्द्रमा राख्नको लागि भित्र कन्टेनर थप्न सक्नुहुन्छ ।
<div class="container">
<nav class="navbar navbar-expand-lg bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
</div>
</nav>
</div>
तपाईंको navbar मा प्रस्तुत गरिएको सामग्री कति फराकिलो छ परिवर्तन गर्न कुनै पनि प्रतिक्रियाशील कन्टेनरहरू प्रयोग गर्नुहोस्।
<nav class="navbar navbar-expand-lg bg-light">
<div class="container-md">
<a class="navbar-brand" href="#">Navbar</a>
</div>
</nav>
नियुक्ति
नेभबारहरू गैर-स्थिर स्थानहरूमा राख्नको लागि हाम्रो स्थिति उपयोगिताहरू प्रयोग गर्नुहोस्। फिक्स्डबाट माथिबाट छान्नुहोस्, फेदमा फिक्स गर्नुहोस्, माथि टाँस्नुहोस् (शीर्षमा नपुगेसम्म पृष्ठसँग स्क्रोल गर्नुहोस्, त्यसपछि त्यहाँ रहन्छ), वा फेदमा टाँस्नुहोस् (तलमा नपुगेसम्म पृष्ठसँग स्क्रोल गर्नुहोस्, त्यसपछि रहन्छ। त्यहाँ)।
फिक्स्ड नेभबारहरू प्रयोग गर्दछ position: fixed
, जसको अर्थ तिनीहरू DOM को सामान्य प्रवाहबाट तानिएका छन् र अन्य तत्वहरूसँग ओभरल्याप हुनबाट जोगाउन अनुकूलन CSS (जस्तै, padding-top
मा ) आवश्यक पर्दछ।<body>
<nav class="navbar bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Default</a>
</div>
</nav>
<nav class="navbar fixed-top bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Fixed top</a>
</div>
</nav>
<nav class="navbar fixed-bottom bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Fixed bottom</a>
</div>
</nav>
<nav class="navbar sticky-top bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Sticky top</a>
</div>
</nav>
<nav class="navbar sticky-bottom bg-light">
<div class="container-fluid">
<a class="navbar-brand" href="#">Sticky bottom</a>
</div>
</nav>
स्क्रोल गर्दै
.navbar-nav-scroll
एक (वा अन्य navbar उप-कम्पोनेन्ट) मा थप्नुहोस् .navbar-nav
भर्टिकल स्क्रोलिङ सक्षम गर्न को लागी एक संक्षिप्त नेभबार को टगल गर्न मिल्ने सामग्रीहरु। पूर्वनिर्धारित रूपमा, स्क्रोलिङले 75vh
(वा भ्युपोर्ट उचाइको ७५%) मा किक गर्छ, तर तपाइँ यसलाई स्थानीय CSS अनुकूलन गुण --bs-navbar-height
वा अनुकूलन शैलीहरूसँग ओभरराइड गर्न सक्नुहुन्छ। ठूला भ्युपोर्टहरूमा जब navbar विस्तार हुन्छ, सामग्री देखा पर्नेछ यो पूर्वनिर्धारित navbar मा हुन्छ।
overflow
कृपया ध्यान दिनुहोस् कि यो व्यवहार -जब सेटिङ overflow-y: auto
(यहाँ सामग्री स्क्रोल गर्न आवश्यक छ) को सम्भावित कमजोरीको साथ आउँछ , overflow-x
को बराबर हो auto
, जसले केही तेर्सो सामग्री क्रप गर्नेछ।
यहाँ इष्टतम स्पेसिङका लागि केही अतिरिक्त मार्जिन उपयोगिताहरू सहित प्रयोग .navbar-nav-scroll
गर्ने एउटा उदाहरण navbar छ।style="--bs-scroll-height: 100px;"
<nav class="navbar navbar-expand-lg 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="#" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Link
</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><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" role="search">
<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>
उत्तरदायी व्यवहार
Navbars ले .navbar-toggler
, .navbar-collapse
, र .navbar-expand{-sm|-md|-lg|-xl|-xxl}
कक्षाहरू प्रयोग गर्न सक्छन् जब तिनीहरूको सामग्री बटन पछाडि पतन हुन्छ निर्धारण गर्न। अन्य उपयोगिताहरूसँग संयोजनमा, तपाइँ सजिलैसँग कहिले देखाउन वा विशेष तत्वहरू लुकाउने छनौट गर्न सक्नुहुन्छ।
कहिले पनि पतन नहुने navbars को लागि .navbar-expand
, navbar मा क्लास थप्नुहोस्। .navbar-expand
सधैं पतन हुने navbars को लागि, कुनै पनि वर्ग नथप्नुहोस् ।
टगलर
नेभबार टगलरहरू पूर्वनिर्धारित रूपमा बायाँ-पङ्क्तिबद्ध हुन्छन्, तर यदि तिनीहरूले एक जस्तै भाइ-बहिनी तत्वलाई पछ्याउँछन् भने .navbar-brand
, तिनीहरू स्वतः टाढा दायाँतिर पङ्क्तिबद्ध हुनेछन्। तपाईको मार्कअपलाई उल्टाउनुले टगलरको प्लेसमेन्टलाई उल्टाउनेछ। तल विभिन्न टगल शैलीहरूको उदाहरणहरू छन्।
.navbar-brand
सबैभन्दा सानो ब्रेकपोइन्टमा देखाइएको छैन :
<nav class="navbar navbar-expand-lg 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" role="search">
<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 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" role="search">
<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 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" role="search">
<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-*
गतिशील र लचिलो नेभिगेसन साइडबार सिर्जना गर्न हाम्रा कक्षाहरू प्रयोग गर्छौं।
तलको उदाहरणमा, एउटा offcanvas navbar सिर्जना गर्न जुन सधैं सबै ब्रेकपोइन्टहरूमा संक्षिप्त हुन्छ, .navbar-expand-*
क्लासलाई पूर्ण रूपमा छोड्नुहोस्।
<nav class="navbar 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" 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="#" role="button" data-bs-toggle="dropdown" 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>
<hr class="dropdown-divider">
</li>
<li><a class="dropdown-item" href="#">Something else here</a></li>
</ul>
</li>
</ul>
<form class="d-flex" role="search">
<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-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>
अँध्यारो नेभबारमा अफक्यानभास प्रयोग गर्दा, पाठ अस्पष्ट हुनबाट जोगिनको लागि तपाईंले अफक्यानभास सामग्रीमा अँध्यारो पृष्ठभूमि हुनुपर्छ भन्ने कुरामा सचेत हुनुहोस्। तलको उदाहरणमा, हामी गाढा अफक्यानभासको साथ उचित स्टाइलको लागि , मा , to , र .navbar-dark
to .bg-dark
थप्छौं ।.navbar
.text-bg-dark
.offcanvas
.dropdown-menu-dark
.dropdown-menu
.btn-close-white
.btn-close
<nav class="navbar navbar-dark bg-dark fixed-top">
<div class="container-fluid">
<a class="navbar-brand" href="#">Offcanvas dark navbar</a>
<button class="navbar-toggler" type="button" data-bs-toggle="offcanvas" data-bs-target="#offcanvasDarkNavbar" aria-controls="offcanvasDarkNavbar">
<span class="navbar-toggler-icon"></span>
</button>
<div class="offcanvas offcanvas-end text-bg-dark" tabindex="-1" id="offcanvasDarkNavbar" aria-labelledby="offcanvasDarkNavbarLabel">
<div class="offcanvas-header">
<h5 class="offcanvas-title" id="offcanvasDarkNavbarLabel">Dark offcanvas</h5>
<button type="button" class="btn-close btn-close-white" 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="#" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Dropdown
</a>
<ul class="dropdown-menu dropdown-menu-dark">
<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" role="search">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-success" type="submit">Search</button>
</form>
</div>
</div>
</div>
</nav>
CSS
चरहरू
v5.2.0 मा थपियोBootstrap को विकसित CSS चर दृष्टिकोण को एक भाग को रूप मा, navbars अब .navbar
परिष्कृत वास्तविक समय अनुकूलन को लागी स्थानीय CSS चर प्रयोग गर्दछ। CSS चरका लागि मानहरू Sass मार्फत सेट गरिएका छन्, त्यसैले Sass अनुकूलन अझै पनि समर्थित छ।
--#{$prefix}navbar-padding-x: #{if($navbar-padding-x == null, 0, $navbar-padding-x)};
--#{$prefix}navbar-padding-y: #{$navbar-padding-y};
--#{$prefix}navbar-color: #{$navbar-light-color};
--#{$prefix}navbar-hover-color: #{$navbar-light-hover-color};
--#{$prefix}navbar-disabled-color: #{$navbar-light-disabled-color};
--#{$prefix}navbar-active-color: #{$navbar-light-active-color};
--#{$prefix}navbar-brand-padding-y: #{$navbar-brand-padding-y};
--#{$prefix}navbar-brand-margin-end: #{$navbar-brand-margin-end};
--#{$prefix}navbar-brand-font-size: #{$navbar-brand-font-size};
--#{$prefix}navbar-brand-color: #{$navbar-light-brand-color};
--#{$prefix}navbar-brand-hover-color: #{$navbar-light-brand-hover-color};
--#{$prefix}navbar-nav-link-padding-x: #{$navbar-nav-link-padding-x};
--#{$prefix}navbar-toggler-padding-y: #{$navbar-toggler-padding-y};
--#{$prefix}navbar-toggler-padding-x: #{$navbar-toggler-padding-x};
--#{$prefix}navbar-toggler-font-size: #{$navbar-toggler-font-size};
--#{$prefix}navbar-toggler-icon-bg: #{escape-svg($navbar-light-toggler-icon-bg)};
--#{$prefix}navbar-toggler-border-color: #{$navbar-light-toggler-border-color};
--#{$prefix}navbar-toggler-border-radius: #{$navbar-toggler-border-radius};
--#{$prefix}navbar-toggler-focus-width: #{$navbar-toggler-focus-width};
--#{$prefix}navbar-toggler-transition: #{$navbar-toggler-transition};
केहि अतिरिक्त CSS चरहरू पनि उपस्थित छन् .navbar-nav
:
--#{$prefix}nav-link-padding-x: 0;
--#{$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: var(--#{$prefix}navbar-color);
--#{$prefix}nav-link-hover-color: var(--#{$prefix}navbar-hover-color);
--#{$prefix}nav-link-disabled-color: var(--#{$prefix}navbar-disabled-color);
CSS चरहरू मार्फत अनुकूलन कक्षामा देख्न सकिन्छ .navbar-dark
जहाँ हामी नक्कल CSS चयनकर्ताहरू थप नगरी विशिष्ट मानहरू ओभरराइड गर्छौं।
--#{$prefix}navbar-color: #{$navbar-dark-color};
--#{$prefix}navbar-hover-color: #{$navbar-dark-hover-color};
--#{$prefix}navbar-disabled-color: #{$navbar-dark-disabled-color};
--#{$prefix}navbar-active-color: #{$navbar-dark-active-color};
--#{$prefix}navbar-brand-color: #{$navbar-dark-brand-color};
--#{$prefix}navbar-brand-hover-color: #{$navbar-dark-brand-hover-color};
--#{$prefix}navbar-toggler-border-color: #{$navbar-dark-toggler-border-color};
--#{$prefix}navbar-toggler-icon-bg: #{escape-svg($navbar-dark-toggler-icon-bg)};
Sass चरहरू
सबै navbars को लागि चर:
$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-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-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-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: var(--#{$prefix}navbar-nav-link-padding-x);
padding-left: var(--#{$prefix}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 {
// stylelint-disable declaration-no-important
position: static;
z-index: auto;
flex-grow: 1;
width: auto !important;
height: auto !important;
visibility: visible !important;
background-color: transparent !important;
border: 0 !important;
transform: none !important;
@include box-shadow(none);
@include transition(none);
// stylelint-enable declaration-no-important
.offcanvas-header {
display: none;
}
.offcanvas-body {
display: flex;
flex-grow: 0;
padding: 0;
overflow-y: visible;
}
}
}
}
}
}