पृष्ठांकन
कागजात र उदाहरणहरू पृष्ठांकन देखाउनको लागि सम्बन्धित सामग्रीको श्रृंखला धेरै पृष्ठहरूमा अवस्थित छ।
अवलोकन
हामी हाम्रो पृष्ठांकनको लागि जडान गरिएका लिङ्कहरूको ठूलो ब्लक प्रयोग गर्छौं, लिंकहरू छुटाउन गाह्रो र सजिलै मापनयोग्य बनाउँदै - ठूला हिट क्षेत्रहरू प्रदान गर्दा। पृष्ठांकन सूची HTML तत्वहरूसँग बनाइएको छ त्यसैले स्क्रिन पाठकहरूले उपलब्ध लिङ्कहरूको संख्या घोषणा गर्न सक्छन्। <nav>
स्क्रिन रिडरहरू र अन्य सहायक प्रविधिहरूमा नेभिगेसन खण्डको रूपमा पहिचान गर्न र्यापिङ तत्व प्रयोग गर्नुहोस् ।
थप रूपमा, पृष्ठहरूमा सम्भवतः एक भन्दा बढी त्यस्ता नेभिगेसन खण्डहरू छन्, यसको उद्देश्य प्रतिबिम्बित गर्नको aria-label
लागि वर्णनात्मक प्रदान गर्न सल्लाह दिइन्छ। <nav>
उदाहरण को लागी, यदि पृष्ठांकन घटक खोज परिणाम को एक सेट को बीच नेभिगेट गर्न को लागी प्रयोग गरिन्छ, एक उपयुक्त लेबल हुन सक्छ aria-label="Search results pages"
।
<nav aria-label="Page navigation example">
<ul class="pagination">
<li class="page-item"><a class="page-link" href="#">Previous</a></li>
<li class="page-item"><a class="page-link" href="#">1</a></li>
<li class="page-item"><a class="page-link" href="#">2</a></li>
<li class="page-item"><a class="page-link" href="#">3</a></li>
<li class="page-item"><a class="page-link" href="#">Next</a></li>
</ul>
</nav>
आइकनहरूसँग काम गर्दै
केही पृष्ठांकन लिङ्कहरूको लागि पाठको स्थानमा प्रतिमा वा प्रतीक प्रयोग गर्न खोज्दै हुनुहुन्छ? aria
विशेषताहरूसँग उचित स्क्रिन रिडर समर्थन प्रदान गर्न निश्चित हुनुहोस् ।
<nav aria-label="Page navigation example">
<ul class="pagination">
<li class="page-item">
<a class="page-link" href="#" aria-label="Previous">
<span aria-hidden="true">«</span>
</a>
</li>
<li class="page-item"><a class="page-link" href="#">1</a></li>
<li class="page-item"><a class="page-link" href="#">2</a></li>
<li class="page-item"><a class="page-link" href="#">3</a></li>
<li class="page-item">
<a class="page-link" href="#" aria-label="Next">
<span aria-hidden="true">»</span>
</a>
</li>
</ul>
</nav>
असक्षम र सक्रिय राज्यहरू
पृष्ठांकन लिङ्कहरू विभिन्न परिस्थितिहरूको लागि अनुकूलन योग्य छन्। .disabled
अन-क्लिक गर्न मिल्ने र .active
हालको पृष्ठ संकेत गर्नका लागि लिङ्कहरू प्रयोग गर्नुहोस्।
.disabled
कक्षाले s को लिङ्क कार्यक्षमता असक्षम गर्ने प्रयास गर्न pointer-events: none
प्रयोग गर्दा , <a>
त्यो CSS गुण अझै मानकीकृत छैन र किबोर्ड नेभिगेसनको लागि खाता छैन। जस्तै, तपाईंले सधैं tabindex="-1"
असक्षम लिङ्कहरूमा थप्नुपर्छ र तिनीहरूको कार्यक्षमता पूर्ण रूपमा असक्षम गर्न अनुकूलन JavaScript प्रयोग गर्नुपर्छ।
<nav aria-label="...">
<ul class="pagination">
<li class="page-item disabled">
<a class="page-link">Previous</a>
</li>
<li class="page-item"><a class="page-link" href="#">1</a></li>
<li class="page-item active" aria-current="page">
<a class="page-link" href="#">2</a>
</li>
<li class="page-item"><a class="page-link" href="#">3</a></li>
<li class="page-item">
<a class="page-link" href="#">Next</a>
</li>
</ul>
</nav>
तपाईं वैकल्पिक रूपमा सक्रिय वा असक्षम एङ्करहरू स्वैप गर्न सक्नुहुन्छ <span>
, वा अघिल्लो/अर्को तीरहरूको अवस्थामा एङ्करलाई हटाउन सक्नुहुन्छ, क्लिक कार्यक्षमता हटाउन र इच्छित शैलीहरू कायम राख्दा किबोर्ड फोकस रोक्न।
<nav aria-label="...">
<ul class="pagination">
<li class="page-item disabled">
<span class="page-link">Previous</span>
</li>
<li class="page-item"><a class="page-link" href="#">1</a></li>
<li class="page-item active" aria-current="page">
<span class="page-link">2</span>
</li>
<li class="page-item"><a class="page-link" href="#">3</a></li>
<li class="page-item">
<a class="page-link" href="#">Next</a>
</li>
</ul>
</nav>
साइजिङ
फेन्सी ठूलो वा सानो पृष्ठांकन? थप्नुहोस् .pagination-lg
वा .pagination-sm
थप आकारहरूको लागि।
<nav aria-label="...">
<ul class="pagination pagination-lg">
<li class="page-item active" aria-current="page">
<span class="page-link">1</span>
</li>
<li class="page-item"><a class="page-link" href="#">2</a></li>
<li class="page-item"><a class="page-link" href="#">3</a></li>
</ul>
</nav>
<nav aria-label="...">
<ul class="pagination pagination-sm">
<li class="page-item active" aria-current="page">
<span class="page-link">1</span>
</li>
<li class="page-item"><a class="page-link" href="#">2</a></li>
<li class="page-item"><a class="page-link" href="#">3</a></li>
</ul>
</nav>
पङ्क्तिबद्धता
फ्लेक्सबक्स उपयोगिताहरूको साथ पृष्ठांकन घटकहरूको पङ्क्तिबद्धता परिवर्तन गर्नुहोस् । उदाहरण को लागी, संग .justify-content-center
:
<nav aria-label="Page navigation example">
<ul class="pagination justify-content-center">
<li class="page-item disabled">
<a class="page-link">Previous</a>
</li>
<li class="page-item"><a class="page-link" href="#">1</a></li>
<li class="page-item"><a class="page-link" href="#">2</a></li>
<li class="page-item"><a class="page-link" href="#">3</a></li>
<li class="page-item">
<a class="page-link" href="#">Next</a>
</li>
</ul>
</nav>
वा संग .justify-content-end
:
<nav aria-label="Page navigation example">
<ul class="pagination justify-content-end">
<li class="page-item disabled">
<a class="page-link">Previous</a>
</li>
<li class="page-item"><a class="page-link" href="#">1</a></li>
<li class="page-item"><a class="page-link" href="#">2</a></li>
<li class="page-item"><a class="page-link" href="#">3</a></li>
<li class="page-item">
<a class="page-link" href="#">Next</a>
</li>
</ul>
</nav>
CSS
चरहरू
v5.2.0 मा थपियोबुटस्ट्र्यापको विकसित CSS चर दृष्टिकोणको भागको रूपमा, पृष्ठांकनले अब .pagination
विस्तारित वास्तविक-समय अनुकूलनको लागि स्थानीय CSS चरहरू प्रयोग गर्दछ। CSS चरका लागि मानहरू Sass मार्फत सेट गरिएका छन्, त्यसैले Sass अनुकूलन अझै पनि समर्थित छ।
--#{$prefix}pagination-padding-x: #{$pagination-padding-x};
--#{$prefix}pagination-padding-y: #{$pagination-padding-y};
@include rfs($pagination-font-size, --#{$prefix}pagination-font-size);
--#{$prefix}pagination-color: #{$pagination-color};
--#{$prefix}pagination-bg: #{$pagination-bg};
--#{$prefix}pagination-border-width: #{$pagination-border-width};
--#{$prefix}pagination-border-color: #{$pagination-border-color};
--#{$prefix}pagination-border-radius: #{$pagination-border-radius};
--#{$prefix}pagination-hover-color: #{$pagination-hover-color};
--#{$prefix}pagination-hover-bg: #{$pagination-hover-bg};
--#{$prefix}pagination-hover-border-color: #{$pagination-hover-border-color};
--#{$prefix}pagination-focus-color: #{$pagination-focus-color};
--#{$prefix}pagination-focus-bg: #{$pagination-focus-bg};
--#{$prefix}pagination-focus-box-shadow: #{$pagination-focus-box-shadow};
--#{$prefix}pagination-active-color: #{$pagination-active-color};
--#{$prefix}pagination-active-bg: #{$pagination-active-bg};
--#{$prefix}pagination-active-border-color: #{$pagination-active-border-color};
--#{$prefix}pagination-disabled-color: #{$pagination-disabled-color};
--#{$prefix}pagination-disabled-bg: #{$pagination-disabled-bg};
--#{$prefix}pagination-disabled-border-color: #{$pagination-disabled-border-color};
Sass चरहरू
$pagination-padding-y: .375rem;
$pagination-padding-x: .75rem;
$pagination-padding-y-sm: .25rem;
$pagination-padding-x-sm: .5rem;
$pagination-padding-y-lg: .75rem;
$pagination-padding-x-lg: 1.5rem;
$pagination-font-size: $font-size-base;
$pagination-color: var(--#{$prefix}link-color);
$pagination-bg: $white;
$pagination-border-radius: $border-radius;
$pagination-border-width: $border-width;
$pagination-margin-start: ($pagination-border-width * -1);
$pagination-border-color: $gray-300;
$pagination-focus-color: var(--#{$prefix}link-hover-color);
$pagination-focus-bg: $gray-200;
$pagination-focus-box-shadow: $input-btn-focus-box-shadow;
$pagination-focus-outline: 0;
$pagination-hover-color: var(--#{$prefix}link-hover-color);
$pagination-hover-bg: $gray-200;
$pagination-hover-border-color: $gray-300;
$pagination-active-color: $component-active-color;
$pagination-active-bg: $component-active-bg;
$pagination-active-border-color: $pagination-active-bg;
$pagination-disabled-color: $gray-600;
$pagination-disabled-bg: $white;
$pagination-disabled-border-color: $gray-300;
$pagination-transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
$pagination-border-radius-sm: $border-radius-sm;
$pagination-border-radius-lg: $border-radius-lg;
सास मिक्सहरू
@mixin pagination-size($padding-y, $padding-x, $font-size, $border-radius) {
--#{$prefix}pagination-padding-x: #{$padding-x};
--#{$prefix}pagination-padding-y: #{$padding-y};
@include rfs($font-size, --#{$prefix}pagination-font-size);
--#{$prefix}pagination-border-radius: #{$border-radius};
}