HTML सूची के लिए अर्थ कैप्शन प्रदान करने का उचित तरीका क्या है ? उदाहरण के लिए, निम्न सूची में "शीर्षक" / "कैप्शन" है।
फल
- सेब
- नाशपाती
- संतरा
शब्द "फल" को कैसे संभाला जाना चाहिए, इस तरह से कि यह शब्द सूची से ही जुड़ा हुआ है?
HTML सूची के लिए अर्थ कैप्शन प्रदान करने का उचित तरीका क्या है ? उदाहरण के लिए, निम्न सूची में "शीर्षक" / "कैप्शन" है।
फल
शब्द "फल" को कैसे संभाला जाना चाहिए, इस तरह से कि यह शब्द सूची से ही जुड़ा हुआ है?
जवाबों:
हालांकि आपके मार्कअप को प्रभावी ढंग से संरचित करने वाला कोई कैप्शन या हेडिंग तत्व नहीं है, इसका एक ही प्रभाव हो सकता है। यहाँ कुछ सुझाव हैं:
नेस्टेड सूची
<ul>
<li>
Fruit
<ul>
<li>Apple</li>
<li>Pear</li>
<li>Organge</li>
</ul>
</li>
</ul>
सूची से पहले शीर्षक
<hX>Fruit</hX>
<ul>
<li>Apple</li>
<li>Pear</li>
<li>Orange</li>
</ul>
परिभाषा सूची
<dl>
<dt>Fruit</dt>
<dd>Apple</dd>
<dd>Pear</dd>
<dd>Orange</dd>
</dl>
<ul>
एक बच्चे के रूप में (या किसी अन्य ब्लॉक-स्तरीय तत्व) के रूप में HTML विनिर्देश के<p>
अनुसार अमान्य है , जिसमें कहा गया है कि केवल "नोड्यूज़िंग कंटेंट" हो सकता है जैसे कि बच्चा नोड्स। <p>
विकल्प 1
एचटीएमएल 5 में तत्व figure
और figcaption
तत्व हैं , जो मुझे काफी अच्छी तरह से काम करते हैं।
उदाहरण:
<figure>
<figcaption>Fruit</figcaption>
<ul>
<li>Apple</li>
<li>Pear</li>
<li>Orange</li>
</ul>
</figure>
फिर इन्हें आसानी से CSS के साथ स्टाइल किया जाता है।
विकल्प 2
छद्म तत्व से पहले CSS3 का उपयोग करना एक अच्छा समाधान हो सकता है:
HTML:
<ul title="Fruit">
<li>Apple</li>
<li>Pear</li>
<li>Orange</li>
</ul>
सीएसएस:
ul[title]::before {
content: attr(title);
/* then add some nice styling as needed, eg: */
display: block;
font-weight: bold;
padding: 4px;
}
आप निश्चित रूप से की तुलना में एक अलग चयनकर्ता का उपयोग कर सकते हैं ul[title]
; उदाहरण के लिए, आप एक 'शीर्षक-जैसा-हेडर' वर्ग जोड़ सकते हैं और ul.title-as-header::before
इसके बजाय उपयोग कर सकते हैं, या आपको जो भी आवश्यक हो।
यह आपको पूरी सूची के लिए टूलटिप देने का दुष्प्रभाव है। यदि आप ऐसा टूलटिप नहीं चाहते हैं, तो आप इसके बजाय एक डेटा विशेषता का उपयोग कर सकते हैं (जैसे, <ul data-title="fruit">
और ul[data-title]::before { content: attr(data-title); }
)।
figure
छवियों से भिन्न सामग्री के साथ किया जा सकता है?
जहां तक मुझे पता है, सूची के लिए कैप्शन प्रदान करने के लिए वर्तमान HTML चश्मा में कोई प्रावधान नहीं हैं, जैसा कि तालिकाओं के साथ है। मैं या तो एक वर्गीकृत पैराग्राफ का उपयोग कर रहा हूं, या एक हेडर टैग के लिए।
<h3>Fruit</h3>
<ul>
<li>Apple</li>
<li>Pear</li>
<li>Orange</li>
</ul>
भविष्य में, एचटीएमएल 5 लाभ जब व्यापक गोद लेने के लिए, आप का उपयोग करने के लिए सक्षम हो जाएगा <legend>
और <figure>
यह थोड़ा और अधिक शब्दार्थ पूरा करने के लिए टैग।
देखें इस पोस्ट में अधिक जानकारी के लिए W3C मेलिंग सूची पर।
यह सुनिश्चित करने के लिए कि स्क्रीन रीडर्स लिस्ट को संबंधित हेडिंग से कनेक्ट करें, आप aria-labelledby
एक हेडिंग से जुड़े का उपयोग इस id
तरह कर सकते हैं:
<h3 id="fruit-id">Fruit</h3>
<ul aria-labelledby="fruit-id">
<li>Apple</li>
<li>Pear</li>
<li>Orange</li>
</ul>
जैसा कि पिछले उत्तर में बताया गया है, सुनिश्चित करें कि आपका शीर्षक स्तर आपके दस्तावेज़ में शीर्ष क्रम का पालन करता है।
मुझे पता है कि यह पुराना है, लेकिन उस उत्तर को जोड़ना चाहता हूं जो मुझे भविष्य के लोगों के लिए मिला: https://www.w3.org/MarkUp/html3/listheader.html
<lh>
तत्व का उपयोग करें :
<ul>
<lh>Types of fruit:</lh>
<li>Apple</li>
<li>Orange</li>
<li>Grape</li>
</ul>
चूंकि मैं पुराने ब्राउज़र समर्थन के साथ एक समाधान खोजने की कोशिश कर रहा था, इसलिए मेरे पास एक अति-सरलीकृत समाधान हो सकता है। तालिका प्रदर्शन शैलियों और आईडी / कक्षाओं का उपयोग करना:
<ul>
<li id="listCaption">My List</li>
<li>first item</li>
<li>second item</li>
<li>third item</li>
</ul>
फिर display: table-row;
सीएसएस में तत्व के लिए शैली लागू करें :
li#listCaption {
display: table-row;
font-size: larger;
text-decoration: underline; }
यह बहुत बेहतर काम करता है यदि आप एक विवरण सूची का उपयोग कर रहे हैं, जो कि मैं वही कर रहा था जब मेरे पास एक ही प्रश्न था। उस स्थिति में, आप <div>
HTML और display: table-caption;
CSS में उपयोग कर सकते हैं , क्योंकि dl सूची में div तत्वों का समर्थन किया गया है:
<dl>
<div id="caption">Table Caption</div>
<dt>term</dt>
<dd>definition</dd>
</dl>
CSS में आप कैप्शन में विभिन्न शैलियों को लागू कर सकते हैं:
#caption {
display: table-caption;
font-family: Arial, Helvetica, sans-serif;
font-size: 20px;
background: transparent;
caption-side: top;
text-align: center; }
मुझे ध्यान देना चाहिए कि table-caption
यह काम नहीं करता है और साथ ही ul/ol
इसे एक ब्लॉक तत्व के रूप में माना जाता है और पाठ को लंबवत रूप से संरेखित किया जाएगा, जिसे आप शायद नहीं चाहते हैं।
मैंने फ़ायरफ़ॉक्स और क्रोम दोनों में यह परीक्षण किया।
आप हमेशा <label/>
लेबल को अपनी सूची तत्व में जोड़ सकते हैं :
<div>
<label for="list-2">TEST</label>
<ul id="list-1">
<li>one</li>
<li>two</li>
<li>three</li>
</ul>
<label for="list-2">TEST</label>
<ol id="list-2">
<li>one</li>
<li>two</li>
<li>three</li>
</ul>
</div>
for
विशेषता चाहिए एक की आईडी होना labelable तत्व है, जो UL
(लेखन के समय) नहीं है ।