टैग सूप
वेब विकास में, टैग सूप वाक्य रचना(प्रोग्रामिंग भाषाएं) या वेब पेज के लिए लिखे गए संरचनात्मक रूप से गलत एचटीएमएल के लिए एक अपमानजनक है। क्योंकि वेब ब्राउज़र ने ऐतिहासिक रूप से एचटीएमएल में संरचनात्मक या वाक्य रचना त्रुटियों को इलाज किया है, वेब विकासकर्ता के लिए प्रकाशित मानकों का पालन करने के लिए थोड़ा दबाव रहा है, और इसलिए टैग सूप की उपस्थिति से निपटने के लिए तंत्र प्रदान करने के लिए सभी ब्राउज़र कार्यान्वयन की आवश्यकता है, जहाँ संभव हो अमान्य सिंटैक्स और संरचना के लिए स्वीकार करना और सुधारना।
एक एचटीएमएल पार्सर (वेब ब्राउज़र का हिस्सा) जो एचटीएमएल जैसी मार्कअप भाषा की व्याख्या करने में सक्षम है, भले ही उसमें अमान्य वाक्य रचना या संरचना हो, उसे टैग सूप पार्सर कहा जा सकता है। सभी प्रमुख वेब ब्राउज़रों में वर्तमान में विकृत एचटीएमएल की व्याख्या के लिए एक टैग सूप पार्सर है, जिसमें अधिकांश त्रुटि प्रबंधन तत्व मानकीकृत हैं।
टैग सूप में कई सामान्य संलेखन गलतियाँ सम्मिलित हैं, जैसे कि अच्छी तरह से निर्मित तत्व,अनुचित रूप से नेस्टेड एचटीएमएल तत्व, और एचटीएमएल में पलायनवादी चरित्र कैरेक्टर एन्कोडिंग (विशेष रूप से एम्परसेंड (&) और कम-से-संकेत (<))।
ब्राउज़रों द्वारा स्वीकार किए जाने वाले पृष्ठों में HTML में टैग की तरह काम करने वाले कोण कोष्ठकों की गड़गड़ाहट को चिह्नित करने के लिए मैंने वर्षों से अपने निर्देश में इस शब्द का उपयोग किया है। अनुचित न्यूनीकरण, ओवरलैपिंग निर्माण ... सामग्री जो एसजीएमएल मार्कअप की तरह दिखती है लेकिन निर्माता एचटीएमएल शब्दावली के लिए एसजीएमएल नियमों को नहीं जानता था या उनका सम्मान नहीं करता था। वास्तव में टेक्स्ट और मार्कअप का एक सूपी संग्रह। [...] मैंने कभी भी कहीं भी इस शब्द को परिभाषित नहीं देखा है।
— G. Ken Holman, Re: [xml-dev] What is Tag Soup?, XML development mailing list, 11 Oct 2002.
W3C मार्कअप सत्यापन सेवा वेब पेज लेखकों के लिए टैग सूप बनाने से बचने के लिए एक संसाधन है।
संक्षिप्त विवरण
टैग सूप एक ऐसा शब्द है जिसका उपयोग वेब संलेखन में विभिन्न प्रथाओं को बदनाम करने के लिए किया जाता है। इनमें से कुछ(मोटे तौर पर सबसे गंभीर से कम गंभीर के क्रम में) में सम्मिलित हैं:
- विकृत मार्कअप जहां टैग अनुचित तरीके से नेस्ट किए गए हैं या गलत तरीके से बंद किए गए हैं। उदाहरण के लिए, निम्नलिखित:
<p>यह <em>HTML का विकृत अंश है।</p></em>
- अमान्य संरचना जहां दस्तावेज़ के लिए डीटीडी के अनुसार तत्वों को अनुचित तरीके से नेस्ट किया गया है। इसके उदाहरणों में एचटीएमएल 4.01 या एक्सएचटीएमएल DTDs में से किसी के लिए "ul" तत्व को सीधे दूसरे "ul" तत्व के अंदर नेस्ट करना सम्मिलित है। डैन कॉनॉली ने हेड सेक्शन के बाहर शीर्षक तत्व के उपयोग का हवाला दिया। डैन कोनोली (कंप्यूटर वैज्ञानिक) हेड सेक्शन के बाहर शीर्षक तत्व के उपयोग का हवाला देते हैं।[1]
- W3C अनुशंसाओं में परिभाषित के अतिरिक्त मालिकाना या अपरिभाषित तत्वों और विशेषताओं का उपयोग। उदाहरण के लिए ब्लिंक तत्व या मार्की तत्व का उपयोग जो गैर-मानक तत्व थे जो मूल रूप से क्रमशः केवल नेटस्केप और इंटरनेट एक्सप्लोरर ब्राउज़रों द्वारा समर्थित थे।
कारण और निहितार्थ
विकृत मार्कअप
वेब संलेखन में विकृत मार्कअप यकीनन सबसे गंभीर समस्या है। हालांकि, बेहतर शिक्षा और जानकारी और शायद एक्सएचटीएमएल की मदद से, विकृत मार्कअप की समस्या कम सामान्य होती जा रही है। ब्राउज़र, जब विकृत मार्कअप का सामना करते हैं, तो उन्हें लेखक के इच्छित अर्थ का अनुमान लगाना चाहिए। उन्हें क्लोजिंग टैग का पता लगाना चाहिए जहां वे उनकी अपेक्षा करते हैं और फिर अन्य क्लोजिंग-टैग से मेल खाने के लिए ओपनिंग टैग का अनुमान लगाते हैं। व्याख्या एक ब्राउज़र से दूसरे ब्राउज़र में स्पष्ट रूप से भिन्न हो सकती है।[2]
जबकि कई ग्राफिकल वेब संपादक अच्छी तरह से गठित मार्कअप का उत्पादन करते हैं, एक लेखक टेक्स्ट-एडिटर के साथ मैन्युअल रूप से कोड लिखता है और फिर केवल एक ब्राउज़र में परीक्षण करके ऐसी त्रुटियों को आसानी से छोड़ सकता है। इसलिए प्रस्तुति एक ब्राउज़र से दूसरे ब्राउज़र में काफी भिन्न हो सकती है क्योंकि प्रत्येक लेखक के इरादे को अलग-अलग तरीकों से ठीक करने का प्रयास करता है और फिर उन सुधारों के लिए स्टाइल लागू करता है।
अवैध दस्तावेज़ संरचना
यहां अमान्य दस्तावेज़ संरचना का अर्थ केवल उन विशेषताओं और तत्वों का उपयोग है जहाँ वे संबंधित नहीं हैं। उदाहरण के लिए, एक उद्धरण तत्व पर एक उद्धरण विशेषता रखना अमान्य है क्योंकि एचटीएमएल और एक्सएचटीएमएल DTDs उस तत्व पर उस विशेषता का कोई अर्थ नहीं बताते हैं। इसी तरह, एम तत्व की सामग्री के भीतर एक पी तत्व भी अमान्य है। विकृत मार्कअप को अमान्य मार्कअप से अलग करने की दिशा में कदम उठाने के साथ, अमान्य मार्कअप की समस्याओं को उत्तरोत्तर कम गंभीर के रूप में देखा जा रहा है। कुछ लोगों ने शिथिल सामग्री मॉडल की वकालत करना शुरू कर दिया है जो एचटीएमएल दस्तावेज़ों (चाहे एचटीएमएल या एक्सएचटीएमएल में) को संलेखित करने में अधिक लचीलेपन की अनुमति देता है। हालांकि, अमान्य मार्कअप का उपयोग लेखक के इच्छित अर्थ को धुंधला कर सकता है, हालांकि विकृत मार्कअप जितना गंभीर नहीं है।
कई ग्राफ़िक वेब संपादक अभी भी अमान्य मार्कअप प्रस्तुत करते हैं। इसके अतिरिक्त, कई पेशेवर वेब डिज़ाइनर और लेखक वैधता के मुद्दों पर बहुत कम ध्यान देते हैं। वर्ल्ड वाइड वेब में कई साइटों में अमान्य मार्कअप देखना सामान्य बात है।
स्वामित्व/बंद तत्वों का उपयोग
वेब के शुरुआती दौर में (1990 के दशक में), आधिकारिक एचटीएमएल विनिर्देशन का डिज़ाइन विज़ुअली जीवंत डिज़ाइन बनाने में लचीलेपन के लिए डिजाइनरों की इच्छा की तुलना में तेजी से तनावपूर्ण हो गया। इस दबाव के प्रत्युत्तर में, ब्राउज़र निर्माताओं ने एकपक्षीय रूप से एचटीएमएल में नई मालिकाना सुविधाएँ जोड़ीं जो उस समय के मानकों से बाहर थीं। इसका मतलब था कि एचटीएमएल में मालिकाना तत्व थे जो कुछ ब्राउज़रों में काम करते थे, लेकिन दूसरों में नहीं।
कुछ हद तक, इस समस्या को W3C द्वारा नए मानकों की शुरुआत से धीमा कर दिया गया था, जैसे कि सीएसएस, 1998 में पेश किया गया, जिसने बड़ी संख्या में अतिरिक्त एचटीएमएल तत्वों की आवश्यकता के बिना वेब पेजों की प्रस्तुति और लेआउट में अधिक लचीलापन प्रदान करने में मदद की। और गुण।
इसके अतिरिक्त, एचटीएमएल 4 और एक्सएचटीएमएल 1 में, कई तत्वों को या तो एक सिमेंटिक निर्माण (जैसे मालिकाना एप्लेट और एम्बेड तत्वों की जगह वस्तु तत्व) द्वारा हटा दिया गया था या प्रस्तुतिकरण (जैसे एस, स्ट्राइक और यू तत्व) के कारण पदावनत किया गया था।
फिर भी, ब्राउज़र विकासकर्ता ने आवश्यकता महसूस होने पर एचटीएमएल में नए तत्वों को पेश करना जारी रखा। कुछ ब्राउज़रों में किसी भी तत्व पर Tabindex विशेषताएँ सम्मिलित हैं। एप्पल के WebKit के विकासकर्ता ने एचटीएमएल कैनवास तत्व पेश किया, जिसका एक संस्करण बाद में mozilla द्वारा अपनाया गया।
2004 में, एप्पल, मोज़िला और ओपेरा सॉफ्टवेयर ने एचटीएमएल विनिर्देशन का एक नया संस्करण बनाने के इरादे से WHATWG की स्थापना की, जो सभी ब्राउज़र व्यवहार से मेल खाएगा। इसमें विभिन्न ब्राउज़रों के बीच मौजूदा सामान्य सहमति से मिलान करने के लिए यदि आवश्यक हो तो विनिर्देश बदलना सम्मिलित है।[3]
कैनवास[4] और एम्बेड करें[5] तत्वों को बाद में WHATWG द्वारा मानकीकृत किया गया। कुछ तत्व (बी, आई और छोटे सहित) जिन्हें पहले प्रस्तुतिकरण और बहिष्कृत माना जाता था, लेकिन दृश्य तरीके के अतिरिक्त मीडिया-स्वतंत्र में परिभाषित किया गया था।[6]
WHATWG विनिर्देशन के संस्करणों को W3C द्वारा एचटीएमएल 5 के रूप में प्रकाशित किया गया था।[3]
टैग सूप को हल करने के लिए विनिर्देशों का विकास
जबकि टैग सूप के कुछ मुद्दे ब्राउज़रों की कमियों के कारण होते हैं और कभी-कभी वेब लेखकों के लिए जानकारी की कमी के कारण, टैग सूप के कुछ प्रसार स्वयं वेब मानकों में लापता लिंक के कारण होते हैं। W3C ने वेब मानकों की कमियों को दूर करने के लिए कई प्रयासों का नेतृत्व किया है। जैसा कि अधिक ब्राउज़र मानकों के नए संशोधनों का समर्थन करते हैं, वेब विकासकर्ता पर समस्याओं को हल करने के लिए गैर-मानक कोड का उपयोग करने का दबाव कम हो जाता है।
व्यापक शैली पत्रक (सीएसएस)
कैस्केडिंग स्टाइल शीट्स (सीएसएस) दस्तावेज़ की मार्कअप संरचना में बदलाव किए बिना दस्तावेज़ में तत्वों की प्रस्तुति को निर्दिष्ट करने के लिए एक तंत्र प्रदान करती है। सीएसएस के सामान्य होने से पहले, वेब विकासकर्ता कुछ प्रस्तुतिकरण लक्ष्यों को प्राप्त करने के लिए कुछ संरचनात्मक रूप से अमान्य मार्कअप का सहारा ले सकते थे - उदाहरण के लिए, एक विशेष प्रभाव प्राप्त करने के लिए इनलाइन तत्वों के भीतर ब्लॉक स्तर के तत्वों को सम्मिलित करना, या कभी-कभी बड़ी संख्या में उपयोग करना <font>
और अन्य प्रदर्शन-विशिष्ट एचटीएमएल टैग। सीएसएस इन कार्यों को पूरा करने के लिए शैली नियमों का उपयोग करता है जबकि मार्कअप को अधिक स्वच्छ और सरल बनाता है।
एक्सएमएल और एक्सएचटीएमएल
एक्सएचटीएमएल, एचटीएमएल पर आधारित एचटीएमएल भाषा का पुनर्संरचना है। एक्सएचटीएमएल को टैग सूप से जुड़ी कई समस्याओं के समाधान के लिए विकसित किया गया था।
एक्सएमएल पार्सर्स को दस्तावेज़ वाक्य रचनाऔर इसकी संरचना की व्याख्या करने की प्रक्रिया को अलग करने की अनुमति देता है। एचटीएमएल और एसजीएमएल में, एक पार्सर को पार्सिंग के दौरान तत्वों के बारे में कुछ नियमों को जानने की आवश्यकता होती है, जैसे कि कौन से तत्व अन्य तत्वों के भीतर समाहित हो सकते हैं और कौन से तत्व पिछले तत्व को पूरी तरह से बंद कर देते हैं। ऐसा इसलिए है क्योंकि एचटीएमएल और एसजीएमएल में, कुछ तत्वों पर क्लोजिंग टैग और यहां तक कि ओपनिंग टैग वैकल्पिक थे। सभी तत्वों को स्पष्ट उद्घाटन और समापन टैग की आवश्यकता के द्वारा, एचटीएमएल पार्सर दस्तावेज़ को पार्स कर सकते हैं और दस्तावेज़ प्रकार के किसी भी ज्ञान के बिना एक दस्तावेज़ ट्री का उत्पादन कर सकते हैं। यह पारसर्स को सार्वभौमिक और बहुत हल्का वजन होने की अनुमति देता है, और दस्तावेज़ को मान्य करने या व्याख्या करने की प्रक्रिया से अलग होने की अनुमति देता है।
एक्सएमएल विनिर्देश स्पष्ट रूप से परिभाषित करता है कि एक अनुरूप उपयोगकर्ता एजेंट (जैसे कि एक वेब ब्राउज़र) को किसी दस्तावेज़ को स्वीकार नहीं करना चाहिए, और यदि कोई सिंटैक्टिकल त्रुटि सामने आती है तो उसे पार्स करना जारी नहीं रखना चाहिए। इस प्रकार, एक वेब पेज को एक्सएचटीएमएल के रूप में व्याख्या करने वाला एक ब्राउज़र पेज को प्रदर्शित करने से इंकार कर देगा यदि यह एक गठन त्रुटि का सामना करता है। एचटीएमएल 5 इस बिंदु पर बचाव के लिए आता है। एचटीएमएल 5 संगत वेब ब्राउज़र टैग सूप को संभालने में सक्षम हैं। एचटीएमएल 5 में फॉरवर्ड और बैकवर्ड कम्पैटिबिलिटी दोनों हैं, इस अर्थ में कि एचटीएमएल 4 को सपोर्ट करने के अलावा इसमें कई नई सुविधाएँ भी हैं। एचटीएमएल 5 ने एचटीएमएल पार्सिंग को पार्स करने के लिए नियम निर्धारित किए हैं जो पहले मौजूद नहीं थे।यह सुनिश्चित करने में मदद कर सकता है कि जब लेखक एक अनुरूप ब्राउज़र के खिलाफ एक्सएचटीएमएल कोड का परीक्षण करते हैं तो उन्हें तुरंत विकृति की समस्याओं के बारे में सूचित किया जाएगा: शायद सबसे गंभीर समस्या जो वेब ब्राउज़र का सामना कर रही है। जब कोड विकृत होता है, तो लेखक का इरादा अस्पष्ट होता है। एचटीएमएल के निर्देशों के बिना, एचटीएमएल ब्राउज़रों को जटिल एल्गोरिदम का उपयोग करके लेखक के इच्छित अर्थ का पता लगाने के लिए उन मामलों की एक विस्तृत श्रृंखला में उपयोग करना चाहिए जहां अमान्य वाक्य रचनाका सामना करना पड़ता है।
एक्सएमएल और एक्सएचटीएमएल नेमस्पेस की अवधारणा का परिचय देते हैं। नामस्थानों के साथ, लेखक या लेखकों के समुदाय नए शब्दार्थों के साथ नए तत्वों और विशेषताओं को परिभाषित कर सकते हैं, और उन्हें अपने एक्सएचटीएमएल दस्तावेज़ों में मिला सकते हैं। नामस्थान यह सुनिश्चित करते हैं कि विभिन्न नामस्थानों से तत्वों के नाम मिश्रित नहीं होंगे। उदाहरण के लिए, एक तालिका तत्व को एक नए नामस्थान में परिभाषित किया जा सकता है जिसमें नए शब्दार्थ एचटीएमएल तालिका तत्व से भिन्न होते हैं और ब्राउज़र दोनों के बीच अंतर करने में सक्षम होगा। नामस्थान प्रदान करने में, सीएसएस के साथ मिलकर एक्सएचटीएमएल संलेखन समुदायों को दस्तावेज़ों की शब्दार्थ शब्दावली को आसानी से विस्तारित करने की अनुमति देता है। यह मालिकाना तत्वों के उपयोग को तब तक समायोजित करता है जब तक कि उन तत्वों को पूर्ण स्टाइल शीट परिभाषाओं (श्रवण/भाषण और स्पर्श शैलियों सहित) के माध्यम से लक्षित दर्शकों को प्रस्तुत किया जा सके।
इंटरनेट मीडिया प्रकार का उपयोग करके वेब पर एक्सएचटीएमएल दस्तावेज़ प्रस्तुत किए जा सकते हैं application/एक्सएचटीएमएल +
एचटीएमएल या text/html
[7] वर्तमान Microsoft इंटरनेट एक्सप्लोरर संस्करण (6, 7 और 8) के रूप में प्रदर्शित एक्सएचटीएमएल दस्तावेज़ प्रदर्शित नहीं करते हैं application/एक्सएचटीएमएल +xml
. आईई9 बीटा रिलीज अनुपालन प्रतीत होता है। एक्सएचटीएमएल#अडॉप्शन भी देखें।
एचटीएमएल
एचटीएमएल 5 का लक्ष्य अब तक टैग सूप की समस्या का सबसे पूर्ण समाधान होना है, जहां तक संभव हो पीछे की ओर- और आगे-संगत के रूप में शेष है। एक्सएचटीएमएल के विपरीत, जो पश्चगामी संगतता से हटता है और यह दृष्टिकोण अपनाता है कि पार्सर बुरी तरह से बनाए गए मार्कअप के प्रति कम सहिष्णु हो जाएं, एचटीएमएल5 स्वीकार करता है कि बुरी तरह से निर्मित एचटीएमएल कोड पहले से ही बड़ी मात्रा में मौजूद है और संभवत: इसका उपयोग जारी रहेगा, और यह विचार करता है कि ऐसे कोड के साथ अधिकतम संगतता सुनिश्चित करने के लिए विनिर्देश का विस्तार किया जाना चाहिए। एचटीएमएल 5 एक मार्कअप भाषा है जिसका उपयोग वर्ल्ड वाइड वेब पर सामग्री को संरचित और प्रस्तुत करने के लिए किया जाता है। यह पाँचवाँ और अंतिम प्रमुख एचटीएमएल संस्करण है जो वर्ल्ड वाइड वेब कंसोर्टियम (W3C) की सिफारिश है। वर्तमान विनिर्देश को एचटीएमएल लिविंग स्टैंडर्ड के रूप में जाना जाता है।
इस प्रकार, एचटीएमएल 5 विनिर्देशन ने एचटीएमएल वाक्य रचनाकी अपनी परिभाषा को बदल दिया है, दोनों आज उपयोग में आने वाले सामान्य वाक्य रचनाको समायोजित करने के लिए, और स्पष्ट रूप से वर्णन करने के लिए कि पार्सर द्वारा कितनी बुरी तरह से बनाए गए कोड का इलाज किया जाना चाहिए। बुरी तरह से बनाए गए कोड को संभालने का अब विनिर्देशन में ही एक स्थान है, उम्मीद है कि भविष्य के एचटीएमएल पार्सर्स की आवश्यकता को कम करने के लिए कोड से निपटने के लिए अतिरिक्त, आउट-ऑफ़-स्पेसिफिकेशन उपायों को लागू करने की आवश्यकता है, जिसे वह पहचान नहीं पाता है।
टैग सूप को ठीक करने के लिए उपकरण
- एचटीएमएल Tidy एक सॉफ्टवेयर टूल है जो कई प्लेटफॉर्म के लिए उपलब्ध है जो अमान्य वाक्य रचनाको ठीक कर सकता है, और सबसे अमान्य दस्तावेज़ संरचना, एचटीएमएल जैसे कोड को एचटीएमएल या एक्सएचटीएमएल में परिवर्तित कर सकता है।
- एग्गोर्नो एक विज़ुअल स्टूडियो ऐड-इन है जो वेबसाइटों को मानकों के अनुरूप बनाने पर केंद्रित है
- टैगसूप एक जावा लाइब्रेरी है जो एचटीएमएल को पार्स करती है, इसे साफ करती है, और अच्छी तरह से गठित एचटीएमएल का प्रतिनिधित्व करने वाली एचटीएमएल घटनाओं के लिए सरल API की एक धारा प्रदान करती है। (आवश्यक रूप से वैध एक्सएचटीएमएल नहीं)। इस उपकरण का उपयोग IcedTea IcedTea-Web|IcedTea-Web, IcedTea की एक उप-परियोजना, OpenJDK के निर्माण और एकीकरण परियोजना में उपलब्ध JNLP प्रोटोकॉल के ओपन सोर्स कार्यान्वयन में JNLP फ़ाइलों को संसाधित करने के लिए किया जाता है।
- ब्यूटीफुल सूप सूपी HTML/एचटीएमएल के लिए Python दस्तावेज़ वस्तु मॉडल जैसा पार्सर है।[8]
- टैगसौप: हास्केल भाषा के लिए एक पुस्तकालय।
एक्सएचटीएमएल से मान्य विचलन
सख्त एक्सएचटीएमएल के विपरीत, एचटीएमएल और इसके पूर्ववर्ती एसजीएमएल को मनुष्यों द्वारा लिखे जाने के लिए डिज़ाइन किया गया है, और बॉयलरप्लेट को कम करने के लिए वाक्य रचनामें पहले से ही लचीलेपन की एक महत्वपूर्ण डिग्री है। ये अंतर दस्तावेज़ को अमान्य नहीं बनाते हैं और इसलिए टैग सूप नहीं हैं। निम्नलिखित एचटीएमएल 4 और एचटीएमएल 5 दोनों पर लागू होता है,[9] और उदाहरण एचटीएमएल के शुरुआती दिनों के हैं। [10]
- टैग पसंद है
<head>...</head>
को अक्सर पूरी तरह से छोड़ा जा सकता है। - टैग को बंद करने को अक्सर छोड़ा जा सकता है क्योंकि विनिर्देश कुछ तत्वों को अपने आप में नेस्ट करने को अस्वीकार करता है। उदाहरण के लिए, बहु
<li>...</li>
तत्वों को बंद किए बिना लिखा जा सकता है।
उनकी वैधता के बावजूद, इन चूकों को अभी भी पार्स करने के लिए एचटीएमएल (अधिक कठोर एचटीएमएल के विपरीत) के ज्ञान के साथ एक विशेष पार्सर की आवश्यकता होती है। इसके अतिरिक्त, उपकरण के लिए इन संरचनाओं को भी ठीक करना सामान्य बात है। उदाहरण के लिए, एचटीएमएल Tidy वैकल्पिक टैग को छोड़ने की अनुमति देता है, लेकिन डिफ़ॉल्ट रूप से ऐसा नहीं करता है।[11]
यह भी देखें
- ओवरलैपिंग मार्कअप
- विचित्र मोड
टिप्पणियाँ
- G. Ken Holman. Re: [xml-dev] What is Tag Soup?, एचटीएमएल development mailing list, 11 Oct 2002. Archived message available online.
- "tag soup." Definitions.net. STANDS4 LLC, 2013. Web. 19 Nov. 2013. soup.
संदर्भ
- ↑
Winer, Dave (12 October 2002). "What is Tag Soup?". Scripting News. Dave Winer. Archived from the original on 26 February 2004. Retrieved 23 November 2017.
The example he cited is the <title> element. It really only makes sense in the <head> of a document, but apparently one or more browsers would let you set the title of a page in the body of the page! It's not like this makes the earth crumble or the sky fall, everything can proceed normally, but it's wrong to do it there and the world would be a (slightly) better place if browsers didn't allow it.
- ↑ Hickson, Ian (21 November 2002). "Tag Soup: How UAs handle <x> <y> </x> </y>". Retrieved 11 September 2020.
- ↑ 3.0 3.1 WHATWG. "1.6 History". HTML Standard.
- ↑ WHATWG. "4.12.5 The canvas element". HTML Standard.
- ↑ WHATWG. "4.8.6 The embed element". HTML Standard.
- ↑ WHATWG. प्रश्न "सामान्य प्रश्न". WHATWG.org.
{{cite web}}
: Check|url=
value (help) - ↑ "XHTML 1.0 The Extensible HyperText Markup Language (Second Edition) A Reformulation of HTML 4 in XML 1.0, Appendic C. HTML Compatibility Guidelines". W3C Recommendation. 1 August 2002 [26 January 2000]. Retrieved 2008-09-13.
XHTML Documents which follow the guidelines set forth in Appendix C, "HTML Compatibility Guidelines" may be labeled with the Internet Media Type "text/html" [RFC2854], as they are compatible with most HTML browsers. Those documents, and any other document conforming to this specification, may also be labeled with the Internet Media Type "application/xhtml+xml" as defined in [RFC3236]. For further information on using media types with XHTML, see the informative note [XHTMLMIME].
- ↑
Tagliaferri, Lisa (20 July 2017). "How To Scrape Web Pages with Beautiful Soup and Python 3". Digital Ocean Tutorials. Digital Ocean. Archived from the original on 2 September 2017. Retrieved 23 November 2017.
Currently available as Beautiful Soup 4 and compatible with both Python 2.7 and Python 3, Beautiful Soup creates a parse tree from parsed HTML and XML documents (including documents with non-closed tags or tag soup and other malformed markup).
- ↑ "§3 एसजीएमएल और एचटीएमएल पर". HTML 4.01 Specification. W3C. 24 December 1999. §3.2.1 Elements.; HTML 5.1 दूसरा संस्करण § 8.1.2.4। वैकल्पिक टैग
- ↑ क्लोजिंग ली को हटाने के लिए एचटीएमएल 2 विनिर्देश § दस्तावेज़ संरचना का स्रोत देखें, और ch/hypertext/WWW/MarkUp/Tags.html मूल एचटीएमएल टैग दस्तावेज़ p और हेड को बंद करने के लिए।
- ↑ "HTML Tidy 5.7.0 Options Quick Reference". api.html-tidy.org (in English).