एक से ज़्यादा <details>
एलिमेंट वाला एक खास अकॉर्डियन बनाएं, जिनमें एक ही name
हो.
अकॉर्डियन
वेब पर यूज़र इंटरफ़ेस (यूआई) का एक सामान्य पैटर्न, अकॉर्डियन कॉम्पोनेंट है. यह एक कॉम्पोनेंट है, जिसमें जानकारी देने वाले कई विजेट शामिल होते हैं. कॉन्टेंट को दिखाने (या छिपाने) के लिए, इस विजेट को अलग-अलग बड़ा या छोटा किया जा सकता है.
वेब पर इस पैटर्न को लागू करने के लिए, कुछ <details>
एलिमेंट को आपस में जोड़ा जाता है. आम तौर पर, उन्हें विज़ुअल ग्रुप में रखा जाता है, ताकि यह पता चल सके कि वे एक साथ इस्तेमाल किए जा सकते हैं.
खास अकॉर्डियन
ब्राउज़र के इस्तेमाल से जुड़ी सहायता
एक्सक्लूज़िव अकॉर्डियन, अकॉर्डियन पैटर्न का एक वैरिएशन है. इसमें एक बार में सिर्फ़ एक डिसक्लोज़र विजेट खोला जा सकता है.
वेब पर खास अकॉर्डियन बनाने के लिए, आपने <details>
एलिमेंट में name
एट्रिब्यूट जोड़ा है. इस एट्रिब्यूट का इस्तेमाल करने पर, एक ही name
वैल्यू वाले कई <details>
एलिमेंट एक सेमैटिक ग्रुप बनाते हैं. साथ ही, ये एक एक्सक्लूज़िव अकॉर्डियन की तरह काम करते हैं. ग्रुप में से कोई एक <details>
एलिमेंट खोलने पर, पिछला एलिमेंट अपने-आप बंद हो जाएगा.
<details name="learn-css">
<summary>Welcome to Learn CSS!</summary>
<p>…</p>
</details>
<details name="learn-css">
<summary>Box Model</summary>
<p>…</p>
</details>
<details name="learn-css">
<summary>Selectors</summary>
<p>…</p>
</details>
किसी पेज पर एक से ज़्यादा एक्सक्लूज़िव अकॉर्डियन हो सकते हैं. जब भी किसी <details>
एलिमेंट पर नई name
वैल्यू का इस्तेमाल किया जाता है, तो एक नया लॉजिकल ग्रुप बन जाता है.
खास अकॉर्डियन के हिस्से के तौर पर मौजूद <details>
एलिमेंट, ज़रूरी नहीं है कि वे एक-दूसरे के भाई-बहन हों. ये दस्तावेज़ में कहीं भी हो सकते हैं. name
एट्रिब्यूट, इन एलिमेंट को ग्रुप में बांटता है, न कि उनके डीओएम क्रम के हिसाब से.
खास अकॉर्डियन को पॉलीफ़िल करना
नीचे दिए गए JavaScript की मदद से, एक्सक्लूज़िव अकॉर्डियन के व्यवहार को पॉलीफ़िल किया जा सकता है. यह कोड, <details>
एलिमेंट के toggle
इवेंट पर निर्भर करता है.
जब name
वाला कोई <details>
एलिमेंट खुलता है, तो कोड name
एट्रिब्यूट की एक ही वैल्यू वाले अन्य खुले हुए <details>
एलिमेंट ढूंढता है और उन्हें बंद कर देता है.
document.querySelectorAll("details[name]").forEach(($details) => {
$details.addEventListener("toggle", (e) => {
const name = $details.getAttribute("name");
if (e.newState == "open") {
document
.querySelectorAll(`details[name=${name}][open]`)
.forEach(($openDetails) => {
if (!($openDetails === $details)) {
$openDetails.removeAttribute("open");
}
});
}
});
});
ब्राउज़र के कुछ पुराने वर्शन, इस toggle
इवेंट को ट्रिगर नहीं करते. उन ब्राउज़र में, पॉलीफ़िल कोड कुछ भी नहीं करेगा. प्रगतिशील तरीके से बेहतर बनाने के मामले में, यह स्वीकार किया जा सकता है.