Unlimited Plugins, WordPress themes, videos & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Code
  2. HTML
Code

कस्टम टैग बनाकर HTML का विस्तार करना

by
Difficulty:BeginnerLength:MediumLanguages:

Hindi (हिंदी) translation by Ashish Rampal (you can also view the original English article)

इस ट्यूटोरियल में मैं आपको दिखाऊंगा कि कस्टम टैग्स के साथ HTML भाषा का विस्तार करना कितना आसान है। कस्टम टैग्स का उपयोग विभिन्न व्यवहारों को लागू करने के लिए किया जा सकता है, इसलिए वे कम कोड लिखने और अपने HTML डाक्यूमेंट्स को आसान बनाए रखने का एक बहुत सुविधाजनक तरीका है।

कस्टम HTML टैग क्या है?

HTML के साथ आप <b> टैग का उपयोग करते हैं, उदाहरण के लिए, बोल्ड टेक्स्ट दिखाने के लिए। यदि आपको एक लिस्ट की आवश्यकता है, तो आप <ul> टैग का उपयोग उसके <li> चाइल्ड टैग के साथ प्रत्येक लिस्ट आइटम के लिए कर सकते हैं। टैग ब्राउज़रों द्वारा व्याख्यित किए जाते हैं, और CSS के साथ, निर्धारित करते हैं कि वेबपेज कंटेंट को कैसे प्रदर्शित करता है और कंटेंट के कुछ हिस्से कैसे व्यवहार करते है।

कभी-कभी, केवल एक HTML टैग का उपयोग वेब एप्लीकेशन में आवश्यक कार्यक्षमता के लिए पर्याप्त नहीं है। आमतौर पर इसका समाधान JavaScript और CSS के साथ कई HTML टैग का उपयोग करके किया जाता है, लेकिन यह समाधान इतना एलिगेंट नहीं है।

एक और अधिक सुरुचिपूर्ण समाधान एक कस्टम टैग का उपयोग करना होगा- एक आइडेंटिफायर जो <> में संलग्न है, जिसका उद्देश्य हमारे इच्छित कार्यप्रणाली को प्रस्तुत करने के लिए ब्राउज़र द्वारा समझा जाता है। नियमित HTML टैग्स के साथ, हमे एक पेज में कई बार एक कस्टम टैग का उपयोग करने में सक्षम होना चाहिए, और हमें कस्टम टैग की कार्यक्षमता में सहायता के लिए टैग विशेषताओं और उप-टैग भी प्राप्त करने में सक्षम होना चाहिए। तो, एक उदाहरण देखें!

उदाहरण # 1: एक Gravatar कस्टम HTML टैग बनाना

चलो एक कस्टम टैग बनाएं जो एक निश्चित ईमेल एड्रेस के लिए Gravatar चित्र प्रदर्शित करेगा। हम इस टैग को <condingdude-gravatar> कॉल करेंगे, और हम ई-मेल एड्रेस को email नाम के एक एट्रिब्यूट के रूप में पास करेंगे।

आप अपने इच्छित कस्टम टैग को जो चाहे वो नाम दे सकते हैं, लेकिन एक बात ध्यान देने योग्य है कि इस उदाहरण में कस्टम टैग का नाम codingdude- से शुरू होता है। अन्य कस्टम टैग के साथ नाम के टकराव से बचने के लिए अपने कस्टम टैग के लिए इस तरह के prefixes का उपयोग करना सबसे अच्छा अभ्यास है। इसके अलावा, यह स्पष्ट रूप से एक अच्छा विचार है कि टैग नामों का उपयोग न करें जो पहले से HTML द्वारा परिभाषित किए गए हैं।

हमारे टैग को कार्यान्वित करने और जांचने के लिए, हमें कुछ चीजें बनाने की आवश्यकता होगी:

  • प्रोजेक्ट फ़ाइलों को रखने के लिए एक फ़ोल्डर; चलो इस फ़ोल्डर को कॉल करें gravatar-custom-tag
  • gravatar-custom-tag फ़ोल्डर के अंदर एक HTML फ़ाइल index.html। इस फ़ाइल में HTML कोड शामिल होगा
  • gravatar-custom-tag फ़ोल्डर के अंदर एक JS फ़ाइल codingdude-gravatar.js। इस फ़ाइल में कस्टम टैग को कार्यान्वित करने वाला जावास्क्रिप्ट कोड होगा।

आइए index.html फ़ाइल को एडिट करें और इसकी कंटेंट इस तरह दिखें:

अगर हम अब ब्राउज़र में index.html को लोड करते हैं, तो परिणाम उतना प्रभावशाली नहीं होगा क्योंकि हमने अभी तक हमारे कस्टम टैग के लिए कोड को कार्यान्वित नहीं किया है:

An example of the custom tag

ध्यान देने योग्य बात यह है कि ब्राउज़र बहुत क्षमा करने वाला है, इसलिए आप एक दस्तावेज़ में अज्ञात टैग रख सकते हैं और ब्राउज़र उन्हें अनदेखा कर देगा। हमारे कस्टम टैग को वास्तव में मेरे ईमेल के लिए Gravatar चित्र प्रदर्शित करने के लिए, हमें पहले यह समझना होगा कि Gravatar कैसे काम करता है।

Gravatar एक ईमेल पते को एक PNG इमेज के URL में अनुवाद करके काम करता है जिसे यूजर ने चुना है अनुवाद ईमेल पते के MD5 हैश की गणना के द्वारा किया जाता है। Gravatar इमेज URL इस तरह दिखता है: https://www.gravatar.com/avatar/EMAIL_MD5_HASH.png तो पहले हमें स्ट्रिंग से MD5 हैश की गणना करने के लिए फ़ंक्शन की आवश्यकता है। इसके लिए हम एक ओपन-सोर्स लाइब्रेरी का उपयोग करेंगे जो कि हम index.html फ़ाइल में जोड़ देंगे:

अब कस्टम टैग के कार्यान्वयन पर चलते हैं। हमें उस कोड को कार्यान्वित करने की आवश्यकता होगी जो पहले दस्तावेज़ में हमारे कस्टम टैग को पहचानती है, और फिर हमें अपने कस्टम टैग की कार्यक्षमता को लागू करने की आवश्यकता है। यह सब हमारे codingdude-gravatar.js फ़ाइल में जाएंगे और यह इस तरह दिखाई देगा:

कोड को देखते हुए, हम फ़ंक्शन customTag() देखते हैं जो नाम (tagName पैरामीटर) से एक कस्टम टैग की घटनाओं को पाता है और उस कस्टम टैग से संबंधित कार्यक्षमता को एक्सेक्यूट करता है (fn पैरामीटर के माध्यम से)

ब्राउज़र को सूचित करने के लिए कि हम नाम tagName के साथ एक कस्टम टैग का उपयोग करेंगे, कुछ ब्राउज़रों (IE विशेष रूप से) के लिए document.createElement(tagName) कॉल आवश्यक है, अन्यथा टैग काम नहीं करेगा।

fn पैरामीटर एक ऐसा फ़ंक्शन है जो कस्टम टैग को क्या करना है उसे करता है। हमारे मामले में, fn codingdudeGravatar() है। यह फ़ंक्शन कस्टम टैग एलिमेंट के संदर्भ में पैरामीटर के रूप में लेता है। यदि कस्टम टैग के पास एक email नाम का एट्रिब्यूट है तो वह उस मान को हमारे ओपन-सोर्स लाइब्रेरी से md5() फ़ंक्शन पर पास कर देगा। नतीजा तब होता है जब Gravatar इमेज का URL तैयार किया जाता है, जो हमारे कस्टम टैग एलिमेंट के अंदर एक <img> के माध्यम से जोड़ा जाता है।

स्क्रिप्ट की अंतिम पंक्ति को customTag() फ़ंक्शन को कस्टम टैग के नाम और इसके संबंधित कार्यान्वयन फ़ंक्शन को कॉल करती है। कस्टम टैग फ़ंक्शन को किसी भी प्रकार के कस्टम टैग के लिए पुन: उपयोग किया जा सकता है; आपको केवल उस फ़ंक्शन को कार्यान्वित करना होगा जो आपके लिए आवश्यक है।

अब, अगर हम एक ब्राउज़र में अपनी index.html फ़ाइल लोड करते हैं, तो हम अपने ईमेल के लिए Gravatar देखेंगे:

Viewing the Gravatar with the text

उदाहरण # 2: पाई चार्ट को ड्रा करने के लिए के लिए उन्नत कस्टम HTML टैग

हमारे पिछले उदाहरण में, हमने एक बहुत ही सरल कस्टम HTML टैग कार्यान्वयन देखा है। आप चाहते हैं कि किसी भी कस्टम टैग को लागू करने के लिए आप उसी एप्रोच का उपयोग कर सकते हैं।

देखते हैं कि एक और उन्नत कस्टम टैग कैसे कार्यान्वित किया जाए, जो कि हम एक पाय चार्ट को ड्रा करने के लिए उपयोग कर सकते हैं। इस कस्टम टैग के लिए आवश्यक फाइल बनाते हैं:

  • एक फ़ोल्डर बनाएँ और इसे नाम दें piechart-custom-tag यह हमारा प्रोजेक्ट फ़ोल्डर होगा
  • piechart-custom-tag फ़ोल्डर के अंदर, एक HTML फ़ाइल बनाएं और इसे index.html नाम दें। इस फ़ाइल में HTML कोड शामिल होगा।
  • साथ ही एक जावास्क्रिप्ट की codingdude-piechart.js फाइल बनाओ जिसमें हमारे कस्टम टैग के कार्यान्वयन शामिल होगा।

कस्टम टैग्स को अक्सर विभिन्न कार्यों के लिए रैपर के रूप में उपयोग किया जाता है। हमारे मामले में, हम एक पाई चार्ट ड्राइंग के लिए एक आवरण के रूप में <codingdude-piechart> टैग का उपयोग करेंगे। यदि आपने जावास्क्रिप्ट और HTML5 कैनवास का उपयोग करने के लिए चार्ट्स ड्रा कैसे करें के बारे में मेरा टुटोरिअल मिस किया है, तो आप एक क्विक झलक लेना चाह सकते हैं। हम उस ट्यूटोरियल से कोड का उपयोग करेंगे और हमारे कस्टम टैग में इसकी कार्यक्षमता को व्रैप करेंगे।

इसलिए codingdude-piechart.js फ़ाइल को एडिट करें और ट्यूटोरियल से निम्नलिखित फ़ंक्शन जोड़ें:

  • drawLine()
  • drawArc()
  • drawPieSlice()
  • Piechart()

अब फ़ाइल index.html को एडिट करते हैं और कुछ इस तरह से पाइ चार्ट की ड्राइंग के लिए कस्टम टैग को रखें:

यहां का उद्देश्य एट्रिब्यूट की width और height का उपयोग करके पाई चार्ट की चौड़ाई और ऊंचाई निर्धारित करना है। colors ऐट्रिब्यूट्स पाई चार्ट के स्लाइस के लिए इस्तेमाल रंग सेट करता है।

जैसा कि पहले उल्लेख किया गया है, यह कस्टम टैग थोड़ा अधिक जटिल है क्योंकि हम इस कस्टम टैग के लिए उप-टैग का उपयोग करना चाहते हैं। हम चार्ट के लिए डेटा सेट करने के लिए यहां <condingdude-data> उप-टैग का उपयोग करना चाहते हैं। अब इस कस्टम टैग के लिए कोड को कार्यान्वित करने के बारे में देखें।

फ़ाइल codingdude-piechart.js में एडिट करें और, पाई चार्ट ट्यूटोरियल से ली गई फ़ंक्शन को निम्न कोड दें:

customTag() फ़ंक्शन उदाहरण #1 में उपयोग किए जाने वाले के समान है। PiechartTag() फ़ंक्शन में <codingdude-piechart>  कस्टम टैग का कार्यान्वयन शामिल है। यह कार्य निम्नलिखित पहलुओं का ध्यान रखता है:

  • यह <canvas> एलिमेंट बनाता है जहां चार्ट तैयार किया जाएगा, और यह कस्टम टैग के अंदर इसे जोड़ता है। कैनवास की चौड़ाई और ऊंचाई को कस्टम टैग के ऐट्रिब्यूट्स से लिया जाता है।
  • यह एलिमेंट की colors एट्रिब्यूट को ढूंढता है और इसे पाइ चार्ट स्लाइस के लिए इस्तेमाल कलर्स के एक array में परिवर्तित करता है।
  • यह पाइ चार्ट को पास किए गए डेटा संरचना में एक-एक करके <codingdude-data>  एलिमेंट्स को लोड करता है। क्योंकि एलिमेंट्स में टेक्स्ट कंटेंट है, ब्राउज़र उन्हें रेंडर करेगा और टेक्स्ट कंटेंट दिखाए जायेंगे। चूंकि हम यह नहीं चाहते हैं, हम डेटा को प्राप्त करने के बाद एलिमेंट्स को हटा सकते हैं।
  • अन्त में, हम Piechart() कंस्ट्रक्टर को आवश्यक विकल्पों के साथ कॉल करते हैं और फिर पाइ चार्ट को ड्रा करने के लिए draw() फ़ंक्शन को कॉल करते हैं।

यदि आप index.html को लोड करते हैं, तो आप देख सकते हैं कि कस्टम टैग को पाई चार्ट के रूप में प्रस्तुत किया गया है और इसे इस तरह दिखना चाहिए:

The custom tag is rendered as a pie chart

और यह है, एक सुंदर पाई चार्ट। <codingdude-data> एट्रिब्यूट्स बदलना इसके अनुसार पाइ चार्ट को बदल देगा। यह वही कस्टम टैग तकनीक, CodeCanyon Inforgraphic Charts और Graphics HTML Tags Library के डेवलपमेंट के लिए इस्तेमाल किया गया था।

Infographic charts and graphics HTML tags library
CodeCanyon से चार्ट्स लाइब्रेरी

लाइब्रेरी में न केवल पाई चार्ट के लिए कस्टम टैग हैं, बल्कि लाइन चार्ट, बार चार्ट्स, और अन्य प्रकार के चार्ट्स के लिए भी शामिल है।

अंतिम विचार

इस ट्यूटोरियल में हमने दो अलग-अलग फ़ंक्शनलिटी के लिए कस्टम HTML टैग्स बनाने का दो उदाहरण देखे हैं। customTag() फ़ंक्शन का उपयोग करके, आप अपने खुद के कस्टम टैग को आसानी से विकसित कर सकते हैं।

यदि आपने इस ट्यूटोरियल का आनंद लिया, तो हमारे पास HTML5 और संबंधित प्रौद्योगिकियों (technologies) पर कई अन्य ट्यूटोरियल्स भी हैं, इसलिए साथ ही साथ, उन्हें जांचने में संकोच न करें।

Advertisement
Advertisement
Advertisement
Advertisement
Looking for something to help kick start your next project?
Envato Market has a range of items for sale to help get you started.