लेबल और टेक्स्ट के विकल्प

स्क्रीन रीडर के लिए उपयोगकर्ता को बोला गया यूज़र इंटरफ़ेस (यूआई) दिखाया जा सके, इसके लिए ज़रूरी एलिमेंट में सही लेबल या टेक्स्ट के विकल्प होने चाहिए. लेबल या टेक्स्ट का विकल्प किसी एलिमेंट को उसका ऐक्सेस किया जा सकने वाला name देता है. यह सुलभता ट्री में एलिमेंट के सिमैंटिक बताने की मुख्य प्रॉपर्टी में से एक है.

जब किसी एलिमेंट के नाम को एलिमेंट की role के साथ जोड़ा जाता है, तो इससे उपयोगकर्ता को जानकारी मिलती है. इससे, वे समझ सकते हैं कि वे किस तरह के एलिमेंट के साथ इंटरैक्ट कर रहे हैं और पेज पर इसे कैसे दिखाया गया है. अगर कोई नाम मौजूद नहीं है, तो स्क्रीन रीडर सिर्फ़ एलिमेंट की भूमिका के बारे में बताता है. कल्पना करें कि आप किसी पेज पर नेविगेट करते हुए, "बटन", "चेकबॉक्स," "इमेज" को बिना किसी अतिरिक्त कॉन्टेक्स्ट के नेविगेट कर सकते हैं. यही वजह है कि एक अच्छे और ऐक्सेस करने लायक अनुभव के लिए लेबल और टेक्स्ट के विकल्प ज़रूरी हैं.

किसी एलिमेंट के नाम की जांच करना

Chrome के DevTools का इस्तेमाल करके किसी एलिमेंट का ऐक्सेस किया जा सकने वाला नाम आसानी से देखा जा सकता है:

  1. किसी एलिमेंट पर राइट क्लिक करें और जांच करें चुनें. इससे DevTools एलिमेंट पैनल खुलता है.
  2. एलिमेंट पैनल में, सुलभता पैनल खोजें. ऐसा हो सकता है कि यह » सिंबल के पीछे छिपा हो.
  3. कंप्यूटेड प्रॉपर्टी ड्रॉपडाउन में, नाम प्रॉपर्टी खोजें.
DevTools सुलभता पैनल, जिसमें किसी बटन के लिए कंप्यूट किया गया नाम दिखाया गया है.

चाहे आप alt टेक्स्ट वाला img देख रहे हों या label वाला input देख रहे हों, इन सभी स्थितियों में एक जैसा नतीजा मिलता है: एलिमेंट को उसका ऐक्सेस किया जा सकने वाला नाम दिया जाता है.

देखें कि नाम मौजूद नहीं हैं या नहीं

किसी एलिमेंट में ऐक्सेस किया जा सकने वाला नाम जोड़ने के कई तरीके हैं. ये तरीके इस बात पर निर्भर करते हैं कि एलिमेंट किस तरह का है. नीचे दी गई टेबल में सबसे सामान्य तरह के एलिमेंट की सूची दी गई है. इन्हें जोड़ने का तरीका जानने के लिए, ऐक्सेस किए जा सकने वाले नाम और लिंक की ज़रूरत है.

दस्तावेज़ों और फ़्रेम को लेबल करना

हर पेज में एक title एलिमेंट होना चाहिए, जो कम शब्दों में यह बताता हो कि पेज किस बारे में है. title एलिमेंट, पेज को उसका ऐक्सेस किया जा सकने वाला नाम देता है. जब कोई स्क्रीन रीडर, पेज पर आता है, तो पहली बार यह टेक्स्ट पढ़कर सुनाया जाता है.

उदाहरण के लिए, नीचे दिए गए पेज का टाइटल "Mar's Maple Bar फ़ास्ट-बेकिंग रेसिपी" है:

<!doctype html>
  <html lang="en">
    <head>
      <title>Mary's Maple Bar Fast-Baking Recipe</title>
    </head>
  <body>
    …
  </body>
</html>

इसी तरह, किसी भी frame या iframe एलिमेंट में title एट्रिब्यूट होने चाहिए:

<iframe title="An interactive map of San Francisco" src="…"></iframe>

iframe के कॉन्टेंट में खुद का title एलिमेंट शामिल हो सकता है. आम तौर पर, स्क्रीन रीडर फ़्रेम की सीमा पर जाकर एलिमेंट की भूमिका—"फ़्रेम"—और ऐक्सेस किए जा सकने वाले नाम के बारे में बताता है. यह नाम title एट्रिब्यूट की मदद से दिया जाता है. इससे उपयोगकर्ता यह तय कर सकता है कि उसे फ़्रेम में जाना है या उसे बायपास करना है.

इमेज और ऑब्जेक्ट के लिए, टेक्स्ट के विकल्प शामिल करें

इमेज को ऐक्सेस किया जा सकने वाला नाम देने के लिए, img के साथ हमेशा alt एट्रिब्यूट होना चाहिए. अगर इमेज लोड नहीं हो पा रही है, तो alt टेक्स्ट का इस्तेमाल प्लेसहोल्डर के तौर पर किया जाता है. इससे उपयोगकर्ताओं को पता चलता है कि इमेज क्या दिखाना चाहती थी.

alt का अच्छा टेक्स्ट लिखना एक कला है. हालांकि, ऐसे कुछ दिशा-निर्देश हैं जिनका पालन किया जा सकता है:

  1. यह पता करें कि इमेज में ऐसा कॉन्टेंट है या नहीं जिसके लिए आस-पास के टेक्स्ट को पढ़ना मुश्किल हो सकता है.
  2. अगर ऐसा है, तो कॉन्टेंट में जितना हो सके उतना कम शब्दों में बताएं.

अगर कोई इमेज सजावट के तौर पर काम करती है और उससे काम का कॉन्टेंट नहीं मिलता है, तो उसे सुलभता ट्री से हटाने के लिए, उसे खाली alt="" एट्रिब्यूट दिया जा सकता है.

लिंक के साथ रैप की गई इमेज में, यह बताने के लिए img की alt एट्रिब्यूट का इस्तेमाल किया जाना चाहिए कि लिंक पर क्लिक करने पर, उपयोगकर्ता कहां नेविगेट करेगा:

<a href="https://en.wikipedia.org/wiki/Google">
  <img alt="Google's wikipedia page" src="google-logo.jpg">
</a>

इसी तरह, अगर इमेज का बटन बनाने के लिए <input type="image"> एलिमेंट का इस्तेमाल किया जाता है, तो उसमें alt टेक्स्ट होना चाहिए. इसमें बताया गया है कि उपयोगकर्ता के बटन पर क्लिक करने से क्या होता है:

<form>
  <label>
    Username:
    <input type="text">
  </label>
  <input type="image" alt="Sign in" src="./sign-in-button.png">
</form>

एम्बेड किए गए ऑब्जेक्ट

आम तौर पर, Flash, PDF या ActiveX जैसे एम्बेड करने के लिए इस्तेमाल किए जाने वाले <object> एलिमेंट में वैकल्पिक टेक्स्ट भी होना चाहिए. इमेज की तरह ही, अगर एलिमेंट रेंडर नहीं हो पाता, तो यह टेक्स्ट दिखता है. वैकल्पिक टेक्स्ट, सामान्य टेक्स्ट के तौर पर object एलिमेंट के अंदर जाता है, जैसे कि नीचे दी गई "सालाना रिपोर्ट":

<object type="application/pdf" data="/report.pdf">
Annual report.
</object>

किसी साइट का अनुभव बेहतर बनाने के लिए बटन और लिंक बेहद ज़रूरी होते हैं. साथ ही, इन दोनों के नाम और पेज आसानी से ऐक्सेस किए जा सकते हैं.

बटन

button एलिमेंट हमेशा अपने टेक्स्ट कॉन्टेंट का इस्तेमाल करके, ऐक्सेस किए जा सकने वाले नाम का पता लगाने की कोशिश करता है. जो बटन form का हिस्सा नहीं हैं उनके लिए, साफ़ तौर पर जानकारी देने वाली कार्रवाई लिखें, क्योंकि टेक्स्ट कॉन्टेंट को ऐक्सेस करने के लिए, आपको बस एक अच्छा नाम बनाने की ज़रूरत होती है.

<button>Book Room</button>

एक मोबाइल फ़ॉर्म, जिस पर &#39;बुक रूम&#39; बटन दिख रहा है.

इस नियम का एक सामान्य अपवाद आइकॉन बटन है. आइकॉन बटन का टेक्स्ट कॉन्टेंट दिखाने के लिए, इमेज या आइकॉन फ़ॉन्ट का इस्तेमाल किया जा सकता है. उदाहरण के लिए, टेक्स्ट को फ़ॉर्मैट करने के लिए, What You You See Is What You Get (WYSIWYG) एडिटर में इस्तेमाल किए गए बटन, आम तौर पर सिर्फ़ ग्राफ़िक सिंबल होते हैं:

बाईं ओर अलाइन करने वाला आइकॉन बटन.

आइकॉन बटन का इस्तेमाल करते समय, aria-label एट्रिब्यूट का इस्तेमाल करके, उन्हें ऐसा नाम दिया जा सकता है जिसे साफ़ तौर पर ऐक्सेस किया जा सके. aria-label, बटन के अंदर मौजूद किसी भी टेक्स्ट कॉन्टेंट को बदल देता है. इससे स्क्रीन रीडर का इस्तेमाल करने वाले किसी भी व्यक्ति को कार्रवाई के बारे में साफ़ तौर पर जानकारी मिलती है.

<button aria-label="Left align"></button>

बटन की तरह ही, लिंक को भी मुख्य रूप से उनके टेक्स्ट कॉन्टेंट से ऐक्सेस किया जा सकने वाला नाम मिलता है. लिंक बनाते समय अच्छा तरीका यह है कि "यहां" या "ज़्यादा पढ़ें" जैसे शब्दों को लिंक करने के बजाय, टेक्स्ट के सबसे अहम हिस्से को लिंक में ही डाला जाए.

जानकारी काफ़ी नहीं है
Check out our guide to web performance <a href="/guide">here</a>.
उपयोगी कॉन्टेंट!
Check out <a href="/guide">our guide to web performance</a>.

यह उन स्क्रीन रीडर के लिए खास तौर पर मददगार है जो पेज पर मौजूद सभी लिंक की सूची बनाने के लिए शॉर्टकट ऑफ़र करते हैं. अगर लिंक में बार-बार एक ही तरह का फ़िलर टेक्स्ट है, तो ये शॉर्टकट ज़्यादा काम के नहीं होंगे:

VoiceOver का लिंक मेन्यू, जिसमें &#39;यहां&#39; शब्द लिखा हुआ है.
macOS के लिए स्क्रीन रीडर, VoiceOver का उदाहरण, जिसमें लिंक से नेविगेट करने का मेन्यू दिखाया गया है.

लेबल फ़ॉर्म के एलिमेंट

फ़ॉर्म एलिमेंट के साथ किसी लेबल को जोड़ने के दो तरीके हैं, जैसे कि चेकबॉक्स. इन दोनों में से किसी एक तरीके से लेबल टेक्स्ट, चेकबॉक्स के लिए क्लिक टारगेट बन जाता है, जो माउस या टचस्क्रीन इस्तेमाल करने वालों के लिए भी मददगार है. किसी लेबल को एलिमेंट के साथ जोड़ने के लिए, इनमें से कोई एक तरीका अपनाएं:

  • इनपुट एलिमेंट को लेबल एलिमेंट के अंदर रखें
<label>
  <input type="checkbox">Receive promotional offers?</input>
</label>
  • या लेबल की for एट्रिब्यूट का इस्तेमाल करके एलिमेंट का id देखें
<input id="promo" type="checkbox"></input>
<label for="promo">Receive promotional offers?</label>

जब चेकबॉक्स को सही तरीके से लेबल किया जाता है, तो स्क्रीन रीडर यह रिपोर्ट कर सकता है कि एलिमेंट में चेकबॉक्स की भूमिका है, उस पर सही का निशान लगा है, और उसका नाम "प्रमोशनल ऑफ़र पाएं?" जैसा कि नीचे VoiceOver के उदाहरण में दिया गया है:

VoiceOver का टेक्स्ट आउटपुट &#39;प्रमोशनल ऑफ़र पाना है?&#39; को दिखा रहा है

TODO: DevSite - आकलन के बारे में सोचें और उसकी जांच करें