टेलविंड जनरेशन Z के लिए बस बूटस्ट्रैप है
अगर मैं एक और ट्वीट या लिंक्डइन पोस्ट देखता हूं जिसमें टेलविंड की प्रशंसा की जाती है जैसे कि यह पहिया के बाद से सबसे अच्छा आविष्कार था, तो मैं उछालने वाला हूं। जब मैं टेलविंड के बारे में सुनता हूं, तो सबसे पहली बात जो मेरे दिमाग में आती है वह है टेल एरिया के आसपास से आने वाली हवा—उर्फ पाद। और मैं बहुत दूर नहीं हूँ! टेलविंड सामान्य रूप से इंटरनेट और वेब विकास को खराब कर रहा है, 2017 के अंत से और अब इसके तीसरे संस्करण पर, मुझे अभी भी नहीं लगता कि इसे सीखने में मस्तिष्क-शक्ति बर्बाद करने का कोई कारण है।
नहीं, मैं बूढ़ा नहीं हूँ ...
मुझे पता है कि पीढ़ी Z 30 वर्ष से अधिक उम्र के किसी भी व्यक्ति को बूढ़ा और अप्रासंगिक समझना पसंद करती है, लेकिन पीढ़ी Z भी सोचती है कि किसी भी चीज़ के रूप में पहचान करना सामान्य है, चाहे वह गाजर हो या साइकिल ♂️, इसलिए जब मैं कोशिश कर रहा हूँ युवा पीढ़ी के लिए सहायक और उत्साहजनक बनें, वयस्कता को प्रभावित करने वाला यह नवीनतम सॉफ्टवेयर विकास के आसपास कुछ बहुत ही अजीब निर्णय ले रहा है जिसे मैं अच्छे विवेक में नहीं कर सकता, बस अनदेखा कर सकता हूं।
एडम वाथन पर एक नोट। टेलविंड के बारे में कोई बात नहीं कर सकता जब तक कि उसका नाम स्पष्ट रूप से उल्लेख न किया जाए। वह शायद एक अच्छा लड़का है, आखिर वह कनाडा से है। मैं उनसे कभी नहीं मिला हूं और उनके बारे में मेरी कोई राय नहीं है। मेरे द्वारा टेलविंड को ट्रैश करने का मतलब उसे एक डेवलपर के रूप में रद्दी करना नहीं है , वास्तव में, अगर कुछ भी है, तो वह एक सभ्य सॉफ्टवेयर इंजीनियर होने की संभावना है, क्योंकि एक CSS फ्रेमवर्क को एक साथ रखने पर, वही CSS इतने सारे बैकएंड इंजीनियरों को काम करने में बहुत निराशा होती है, है कोई छोटा करतब नहीं। इसके अतिरिक्त, वह अभी भी परियोजना पर सक्रिय है, कुछ ऐसा नहीं है जिसके साथ कई ओपन-सोर्स फ्रेमवर्क और लाइब्रेरी मालिक दावा कर सकते हैं। हालांकि, इनमें से कोई भी Tailwind को अच्छा या आवश्यक नहीं बनाता है।
चलिए समय को थोड़ा पीछे घुमाते हैं। 2011 के आसपास, मैंने कंकाल की खोज की । मानो या न मानो, उस समय अभी भी बहुत सारे सॉफ़्टवेयर डिज़ाइनर और इंजीनियर थे जिन्होंने कसम खाई थी कि मोबाइल वेब ब्राउज़िंग कभी शुरू नहीं होने वाली थी , यह केवल एक अल्पकालिक सनक होने वाली थी। आह-हा! सनक, मेरे गधे। जिस क्षण मैंने उत्तरदायी डिज़ाइन और CSS मीडिया प्रश्न सीखे, मेरा जीवन बदल गया।
अगली खोज ZURB द्वारा फाउंडेशन और उसके तुरंत बाद, बूटस्ट्रैप थी । पूर्व, मैं कसम खाता था, बाद वाला मैंने केवल तब उपयोग किया जब परियोजना ने इसे निर्धारित किया, लेकिन मैं दोनों में धाराप्रवाह था। सार्वजनिक मंचों पर, बेशक, मैं बूटस्ट्रैप को रद्दी बना रहा था और फाउंडेशन की प्रशंसा कर रहा था। करीब एक दशक पहले लोगों के बीच जो झगड़े हुए थे, आप विश्वास नहीं करेंगे... जब तक आप टेलविंड के बारे में कोई थ्रेड नहीं देखेंगे, सिवाय इसके कि यह बूटस्ट्रैप बनाम फाउंडेशन नहीं, बल्कि टेलविंड बनाम सीएसएस है। और यहीं से बकवास फिर से शुरू हो जाती है।
"लेकिन मुझे यह जानने की ज़रूरत नहीं है कि हुड के नीचे क्या है ..."
ओह, लेकिन हाँ, आप बहुत कुछ करते हैं! यदि कोई डेवलपर मेरे पास कभी यह पूछने के लिए आता है कि 17 उपयोगिता वर्गों को जोड़ने के बाद डिजाइन उस तरह क्यों नहीं दिखता है जैसा कि माना जाता है, तो मेरी एकमात्र प्रतिक्रिया "आगे बढ़ो, मेरे बच्चे, और सीएसएस सीखो " होगी । टेलविंड के साथ मेरा पहला पालतू-व्यंग्य यह है कि यह उसी अज्ञानी "वेब डेवलपर्स" को उत्पन्न करता है जो बूटस्ट्रैप और यहां तक कि फाउंडेशन ने दिन में वापस किया था। हेक, बहुत शुरुआती दिनों में, अपना करियर शुरू करने से पहले, मैं उनमें से एक था। मेरी हर समस्या, मैंने अभी तक एक और वर्ग के साथ हल किया है, मैं समय लेने वाले प्रमुख रिफैक्टर भी करता हूं क्योंकि कुछ वर्ग दूसरों के साथ अच्छा नहीं खेलते हैं, जबकि वास्तव में मैं सरल सीएसएस की दो पंक्तियां लिख सकता था।
कोई Tailwind .vs CSS नहीं है। टेलविंड एक सीएसएस फ्रेमवर्क है, आपको सीएसएस सीखना होगा। इससे बचने का कोई रास्ता नहीं है, और एक बार जब आप ऐसा कर लेते हैं, तो आपको टेलविंड की आवश्यकता बंद हो जाती है।
यह लगभग वही समस्या है जो जावास्क्रिप्ट दुनिया में मौजूद है। लोग रिएक्ट सीखते हैं, लेकिन जावास्क्रिप्ट की कोई बुनियादी समझ नहीं है। हेक, यहां तक कि उनमें से कई जो सिर्फ रिएक्ट से परे जाते हैं, वे टाइपस्क्रिप्ट सीखते हैं क्योंकि कुछ गुमराह मूर्खों ने उन्हें शाश्वत मोक्ष की कुंजी के रूप में बेच दिया। वहाँ वास्तविक वेब डेवलपर हैं जिन्होंने जावास्क्रिप्ट की एक भी पंक्ति कभी नहीं लिखी। डोम एपीआई के साथ काम करना? हाहाहा! यह कुछ विदेशी बकवास है, यार! नहीं, हम नेक्स्ट.जेएस की संपूर्णता को स्थापित करेंगे, रेफरी के लिए कोड की अनगिनत पंक्तियाँ लिखेंगे, और अब हम एक डिव के उस सकर को संशोधित कर सकते हैं! क्योंकि सब कुछ एक div है। सिमेंटिक HTML, बिल्कुल CSS की तरह, पीढ़ी Z के साथ बहुत असंगत है ।
हालांकि यह कोई नई समस्या नहीं है...
वेब की शुरुआत के बाद से, लोगों ने हमेशा वेब पृष्ठों को लिखने का तरीका सीखे बिना वितरित करने का प्रयास किया। आप में से बहुत से लोग याद रखने के लिए बहुत छोटे हैं, लेकिन अगर आप देखने की परवाह करते हैं, तो Adobe द्वारा Dreamweaver कुछ वास्तव में दिलचस्प दिखने वाली (अच्छे तरीके से नहीं) CSS कक्षाएं और आईडी उत्पन्न करता है।
यह एक मोहक संभावना है - व्यापार के उपकरण सीखे बिना बनाने के लिए। अंततः, यह हमेशा या तो आपदा में समाप्त होता है, या अच्छे राजभाषा ज्ञान को स्वीकार करता है।
पुस्तकालय या ढांचे के आधार पर खड़ी भाषा सीखने के बाद, किसी के दृष्टिकोण में मौलिक बदलाव होता है। जब CSS की बात आती है, तो आप महसूस करते हैं कि यह कितना शक्तिशाली हो सकता है, और ऐसा कुछ भी नहीं है जिसे आप इसके साथ प्राप्त नहीं कर सकते हैं। ठीक अनाज नियंत्रण जिसे आप अंततः चाहते हैं, सीएसएस में बनाया गया है, लेकिन टेलविंड में नहीं। विकिपीडिया पर उनके उदाहरण को देखते हुए:
<div class="m-4 p-4 bg-yellow-200 font-bold rounded-lg">
<p>Please be careful when feeding the birds.</p>
</div>
टेलविंड एक गैर-हस्तांतरणीय कौशल है। एक सीवी पर एक भनभनाहट जो अंततः आपको नौकरी दिलाने में विफल होगी।
उपरोक्त उदाहरण में परेशान करने वाली बात यह है कि साधारण CSS या यहाँ तक कि SASS में ऐसा करने के लिए वास्तव में कुछ भी आकर्षक नहीं है। उल्लेख नहीं करने के लिए, अब हमारे पास CSS चर हैं , और वे IE के अलावा, सभी ब्राउज़रों में बहुत अच्छी तरह से समर्थित हैं।
इसके बाद डिबगिंग की समस्या आती है, क्योंकि, हां, जितनी अधिक वेबसाइटें और वेब ऐप्स आप बनाते हैं, उतना ही अधिक आप महसूस करेंगे कि कुछ विचित्र बग CSS से संबंधित होंगे । अब यह पता लगाने की कोशिश करें कि क्या टेलविंड में कोई बग है या आपका कोड है। वर्तमान में 8 अंक खुले हैं - जो इसके लायक है, वह बहुत कम है - और 2800 बंद हैं , जो अभी भी CSS की तुलना में 2808 अधिक है। अपने देव टूल्स में कुछ नए हैंड-कोडेड CSS को आज़माना चाहते हैं? आपको शुभकामनाएँ। आपको पहले अपना HTML कोड संपादित करना होगा। प्रदर्शन वास्तव में Tailwind मुखपृष्ठ पर है !
अब, उस होमपेज के बारे में बात करते हुए, मैं टेलविंड के निर्माता एडम वाथन से बहुत असहमत हूं।
मैंने इस बारे में कुछ हज़ार शब्द लिखे हैं कि पारंपरिक "सिमेंटिक क्लास नाम" के कारण CSS को बनाए रखना कठिन क्यों है, लेकिन सच्चाई यह है कि आप मुझ पर तब तक विश्वास नहीं करेंगे जब तक आप वास्तव में इसे आज़माते नहीं हैं। यदि आप इसे एक मौका देने के लिए लंबे समय तक पीछे हटने की इच्छा को दबा सकते हैं, तो मुझे वास्तव में लगता है कि आप आश्चर्यचकित होंगे कि आपने सीएसएस के साथ किसी अन्य तरीके से कैसे काम किया। — एडम वाथन
मैं सामान्य रूप से सीएसएस और वेब परियोजनाओं के साथ उनके व्यक्तिगत अनुभव पर सवाल नहीं उठा रहा हूं, लेकिन हमें यह नहीं भूलना चाहिए कि दुनिया कम से कम 50 रंगों की है। उसके लिए, सीएसएस के साथ एक बुरा अनुभव होना उतना ही अप्रासंगिक है जितना कि मुझे ब्लूबेरी के साथ एक बुरा अनुभव है। यह ब्लूबेरी को खराब नहीं करता है, बस मुझे उनसे एलर्जी है। वही सीएसएस के लिए जाता है। उन्होंने एक समस्या का अनुभव किया, लेकिन उस समस्या को साझा करना जरूरी नहीं है, और जिस तरह फ्लैट 7Up हर चीज (या कुछ भी) का इलाज नहीं है , उसी तरह Tailwind भी नहीं है।
मैंने छोटे से बड़े अनुप्रयोगों, बहु और मोनोरेपो, मोनोलिथ और माइक्रो-फ्रंटेंड पर काम किया, और एक इंजीनियरिंग समूह के रूप में हमें एक बार भी ऐसा नहीं लगा कि CSS हमारी समस्या थी । Angular.js एक समस्या थी, मोनोलिथ एक समस्या थी, jQuery एक समस्या थी, हर दो साल में खरोंच से घटक लिखना एक समस्या थी। लेकिन सीएसएस? कभी नहीँ। एक बार नहीं। हमें अब तक का सबसे आसान निर्णय CSS के आसपास करना था। समूह को एक घंटे का समय दें और वे कुछ तय कर लेंगे। वह CSS, SASS, LESS, JSS हो, जो भी हो, कोई भी टीम और इंजीनियरिंग संगठन जिसका मैं कभी भी हिस्सा नहीं था, को लगा कि "CSS समस्या को हल करने" की आवश्यकता है, और यदि आप अभी सोच रहे हैं तो मैं ठीक वही कर रहा हूँ जो मैं कर रहा हूँ आदम ने किया था, और मेरे दृष्टिकोण को थोपने की कोशिश कर रहा है, आप गलत नहीं हैं, और यह बात भी कुछ ऐसी ही है।
डेवलपर्स मानते हैं कि सभी को समान समस्या है, इसलिए वे उन्हें ठीक करने के लिए उपकरण बनाते हैं। वे उपकरण का प्रचार इस हद तक करते हैं कि लोग मान लेते हैं कि कोई समस्या है, और उपकरण को आँख बंद करके अपना लेते हैं।
आप देखते हैं, टेलविंड, बूटस्ट्रैप, फाउंडेशन घटक या यूआई लिखने और सीएसएस का उपयोग करने के बीच मुख्य अंतर यह है कि बाद वाला एक कोर, हस्तांतरणीय कौशल है जो आपको वेब यूआई में निपुणता प्रदान करता है । यह एक ऐसी चीज है जिसमें कोई CSS फ्रेमवर्क कभी भी आपकी मदद नहीं करेगा।
एक फिसलन भरी, महंगी ढलान…
टेलविंड सीएसएस एक गेटवे ड्रग है। आइए यह न भूलें कि एडम एक टेक कंपनी के सीईओ हैं। उन्होंने एक सॉफ्टवेयर इंजीनियर के रूप में अपनी नौकरी छोड़ दी और पाठ्यक्रम, टेलविंड बनाने और सॉफ्टवेयर विकास पर किताबें लिखने लगे। एक सीईओ के रूप में, वह पैसा बनाना चाहते हैं और यह कैसे करना चाहते हैं, लेकिन एक सशुल्क उत्पाद, टेलविंड यूआई के लिए एक ओपन-सोर्स कोर — टेलविंड सीएसएस — बनाना चाहते हैं । क्या? आपने सोचा था कि लोग अरबों डेवलपरों को उपयोग करने के लिए मुफ्त सामग्री दे देते हैं और इससे उन्हें कुछ नहीं मिलता? आरओएफएल!
यह स्पष्ट करने के लिए कि टेलविंड डेवलपर्स और कंपनियों के लिए एक महंगी गेटवे दवा क्यों है, आइए एक साधारण टेलविंड यूआई बैनर घटक के लिए स्रोत कोड देखें :
<div class="relative isolate flex items-center gap-x-6 overflow-hidden bg-gray-50 px-6 py-2.5 sm:px-3.5 sm:before:flex-1">
<div class="absolute left-[max(-7rem,calc(50%-52rem))] top-1/2 -z-10 -translate-y-1/2 transform-gpu blur-2xl" aria-hidden="true">
<div class="aspect-[577/310] w-[36.0625rem] bg-gradient-to-r from-[#ff80b5] to-[#9089fc] opacity-30" style="clip-path: polygon(74.8% 41.9%, 97.2% 73.2%, 100% 34.9%, 92.5% 0.4%, 87.5% 0%, 75% 28.6%, 58.5% 54.6%, 50.1% 56.8%, 46.9% 44%, 48.3% 17.4%, 24.7% 53.9%, 0% 27.9%, 11.9% 74.2%, 24.9% 54.1%, 68.6% 100%, 74.8% 41.9%)"></div>
</div>
<div class="absolute left-[max(45rem,calc(50%+8rem))] top-1/2 -z-10 -translate-y-1/2 transform-gpu blur-2xl" aria-hidden="true">
<div class="aspect-[577/310] w-[36.0625rem] bg-gradient-to-r from-[#ff80b5] to-[#9089fc] opacity-30" style="clip-path: polygon(74.8% 41.9%, 97.2% 73.2%, 100% 34.9%, 92.5% 0.4%, 87.5% 0%, 75% 28.6%, 58.5% 54.6%, 50.1% 56.8%, 46.9% 44%, 48.3% 17.4%, 24.7% 53.9%, 0% 27.9%, 11.9% 74.2%, 24.9% 54.1%, 68.6% 100%, 74.8% 41.9%)"></div>
</div>
<div class="flex flex-wrap items-center gap-x-4 gap-y-2">
<p class="text-sm leading-6 text-gray-900">
<strong class="font-semibold">GeneriCon 2023</strong><svg viewBox="0 0 2 2" class="mx-2 inline h-0.5 w-0.5 fill-current" aria-hidden="true"><circle cx="1" cy="1" r="1" /></svg>Join us in Denver from June 7 – 9 to see what's coming next.
</p>
<a href="#" class="flex-none rounded-full bg-gray-900 px-3.5 py-1 text-sm font-semibold text-white shadow-sm hover:bg-gray-700 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-gray-900">Register now <span aria-hidden="true">→</span></a>
</div>
<div class="flex flex-1 justify-end">
<button type="button" class="-m-3 p-3 focus-visible:outline-offset-[-4px]">
<span class="sr-only">Dismiss</span>
<svg class="h-5 w-5 text-gray-900" viewBox="0 0 20 20" fill="currentColor" aria-hidden="true">
<path d="M6.28 5.22a.75.75 0 00-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 101.06 1.06L10 11.06l3.72 3.72a.75.75 0 101.06-1.06L11.06 10l3.72-3.72a.75.75 0 00-1.06-1.06L10 8.94 6.28 5.22z" />
</svg>
</button>
</div>
</div>
इसलिए, स्वाभाविक रूप से, आप स्वयं कोड के साथ आने के बजाय टेलविंड यूआई लाइसेंस के लिए डॉलहेयर खाँसी करेंगे । और वह लाइसेंसिंग मॉडल भी चतुर है। आपको लगता है कि एक टीम लाइसेंस के लिए 749 यूरो (टैक्स अतिरिक्त) कंपनी के संदर्भ में आपको चाहिए, लेकिन आप गलत होंगे, क्योंकि एक टीम केवल 25 लोगों तक की अनुमति दे सकती है! अगर मुझे ठीक से याद है, मेरी पिछली नौकरियों में से एक में, हमारे पास लगभग 13 टीमें हुआ करती थीं, तो 13 × 749 लगभग 10K है। निश्चित रूप से, साइट का दावा है कि यह एक बार का शुल्क है, लेकिन तब तक देखें जब तक कि लाइसेंसिंग मॉडल में बदलाव न हो - जैसे कि यह कई अन्य लोगों के लिए बदल गया हो - और कुछ अधिक आर्थिक रूप से टिकाऊ होने के लिए आगे बढ़ें, और आप स्पेगेटी कोड के लिए सदस्यता का भुगतान करेंगे । मुझ पर विश्वास मत करो? सामग्री यूआईपहले से ही ठीक यही करता है! और मैं इसे किसी ऐसे व्यक्ति के रूप में इंगित कर रहा हूं जो एमयूआई का बड़ा प्रशंसक हुआ करता था। हुआ करता था... यहाँ ऑपरेटिव शब्द होना।
अब आप न केवल एक गैर-हस्तांतरणीय कौशल के साथ फंस गए हैं, बल्कि इसका उपयोग करने के लिए भुगतान भी करना होगा। आप गंभीरता से मुझे नहीं बता सकते कि इसमें कुछ भी गलत नहीं है।
समापन में, मैं वास्तव में शीर्षक में बहुत दयालु हो रहा हूँ। तकनीकी रूप से, टेलविंड बूटस्ट्रैप की तुलना में एक बुरा विकल्प है , हालांकि इसका एक समान उद्देश्य है। हालांकि, बूटस्ट्रैप, टेलविंड के रूप में कौशल सेट मूल्य के मामले में उतना ही विवादास्पद है, कम से कम यह वास्तव में एमआईटी लाइसेंस के तहत मुफ़्त है । हालांकि, टेलविंड के मामले में, यह केवल इसके सीएसएस कोर पर लागू होता है , जिससे यह एक बहुत ही अलग कहानी बन जाती है और नीचे जाने के लिए बहुत अधिक खतरनाक रास्ता बन जाता है।
फैसला अनिवार्य रूप से सिर्फ सीएसएस से चिपके रहने के पक्ष में है। इसकी कोई कीमत नहीं है, और यह एक अमूल्य, हस्तांतरणीय कौशल है।
अक्का की कहानी क्लासिक ओपन सोर्स में हर उस चीज़ का सटीक उदाहरण है जो गलत हैएटिला वागो - सॉफ्टवेयर इंजीनियर एक समय में दुनिया को कोड की एक पंक्ति में सुधार करता है। कूल निडर हमेशा से, कोड और ब्लॉग के लेखक। वेब एक्सेसिबिलिटी एडवोकेट, लेगो फैन, विनाइल रिकॉर्ड कलेक्टर। क्राफ्ट बियर पसंद है! मेरी हैलो कहानी यहाँ पढ़ें! लेगो , टेक , कोडिंग और एक्सेसिबिलिटी के बारे में अधिक कहानियों के लिए सदस्यता लें और/या सदस्य बनें ! अपने कम नियमित पाठकों के लिए, मैं यादृच्छिक बिट्स और लेखन के बारे में भी लिखता हूँ ।