You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Web-Dev-For-Beginners/translations/hi/3-terrarium/2-intro-to-css
leestott 7cfaffabb5
🌐 Update translations via Co-op Translator
7 days ago
..
README.md 🌐 Update translations via Co-op Translator 7 days ago
assignment.md 🌐 Update translations via Co-op Translator 2 weeks ago

README.md

टेरारियम प्रोजेक्ट भाग 2: CSS का परिचय

CSS का परिचय

स्केच नोट Tomomi Imura द्वारा

प्री-लेक्चर क्विज़

प्री-लेक्चर क्विज़

परिचय

CSS, या Cascading Style Sheets, वेब विकास की एक महत्वपूर्ण समस्या को हल करता है: आपकी वेबसाइट को सुंदर कैसे बनाया जाए। अपने ऐप्स को स्टाइल करना उन्हें अधिक उपयोगी और आकर्षक बनाता है; आप CSS का उपयोग Responsive Web Design (RWD) बनाने के लिए भी कर सकते हैं - जिससे आपके ऐप्स किसी भी स्क्रीन आकार पर अच्छे दिखें। CSS केवल आपके ऐप को सुंदर बनाने के लिए नहीं है; इसके स्पेसिफिकेशन में एनिमेशन और ट्रांसफॉर्म्स भी शामिल हैं, जो आपके ऐप्स के लिए उन्नत इंटरैक्शन सक्षम कर सकते हैं। CSS वर्किंग ग्रुप वर्तमान CSS स्पेसिफिकेशन को बनाए रखने में मदद करता है; आप उनके काम को World Wide Web Consortium की साइट पर देख सकते हैं।

ध्यान दें, CSS एक ऐसी भाषा है जो वेब की तरह विकसित होती रहती है, और सभी ब्राउज़र्स नए स्पेसिफिकेशन के हिस्सों का समर्थन नहीं करते। हमेशा CanIUse.com पर जाकर अपनी इम्प्लीमेंटेशन की जांच करें।

इस पाठ में, हम अपने ऑनलाइन टेरारियम में स्टाइल जोड़ेंगे और CSS के कई कॉन्सेप्ट्स के बारे में जानेंगे: कैस्केड, इनहेरिटेंस, और सेलेक्टर्स, पोजिशनिंग, और CSS का उपयोग करके लेआउट बनाना। इस प्रक्रिया में हम टेरारियम का लेआउट बनाएंगे और वास्तविक टेरारियम तैयार करेंगे।

पूर्वापेक्षा

आपके टेरारियम के लिए HTML तैयार होना चाहिए और स्टाइलिंग के लिए तैयार होना चाहिए।

वीडियो देखें

Git और GitHub बेसिक्स वीडियो

कार्य

अपने टेरारियम फोल्डर में एक नया फाइल बनाएं जिसका नाम style.css हो। उस फाइल को <head> सेक्शन में इम्पोर्ट करें:

<link rel="stylesheet" href="./style.css" />

कैस्केड

Cascading Style Sheets इस विचार को शामिल करता है कि स्टाइल 'कैस्केड' करते हैं, जिससे स्टाइल का एप्लिकेशन उसकी प्राथमिकता द्वारा निर्देशित होता है। वेबसाइट लेखक द्वारा सेट किए गए स्टाइल ब्राउज़र द्वारा सेट किए गए स्टाइल पर प्राथमिकता लेते हैं। 'इनलाइन' सेट किए गए स्टाइल बाहरी स्टाइल शीट में सेट किए गए स्टाइल पर प्राथमिकता लेते हैं।

कार्य

अपने <h1> टैग में "color: red" इनलाइन स्टाइल जोड़ें:

<h1 style="color: red">My Terrarium</h1>

फिर, अपने style.css फाइल में निम्नलिखित कोड जोड़ें:

h1 {
 color: blue;
}

आपकी वेब ऐप में कौन सा रंग दिखता है? क्यों? क्या आप स्टाइल्स को ओवरराइड करने का तरीका ढूंढ सकते हैं? आप ऐसा कब करना चाहेंगे, या क्यों नहीं?


इनहेरिटेंस

स्टाइल्स एक पूर्वज स्टाइल से एक वंशज तक इनहेरिट होते हैं, जिससे नेस्टेड एलिमेंट्स अपने पैरेंट्स के स्टाइल्स को इनहेरिट करते हैं।

कार्य

बॉडी का फॉन्ट एक दिए गए फॉन्ट पर सेट करें, और नेस्टेड एलिमेंट के फॉन्ट को जांचें:

body {
	font-family: helvetica, arial, sans-serif;
}

अपने ब्राउज़र के कंसोल में 'Elements' टैब खोलें और H1 के फॉन्ट को देखें। यह अपने फॉन्ट को बॉडी से इनहेरिट करता है, जैसा कि ब्राउज़र में बताया गया है:

इनहेरिटेड फॉन्ट

क्या आप नेस्टेड स्टाइल को एक अलग प्रॉपर्टी इनहेरिट करा सकते हैं?


CSS सेलेक्टर्स

टैग्स

अब तक, आपकी style.css फाइल में केवल कुछ टैग्स स्टाइल किए गए हैं, और ऐप काफी अजीब दिखता है:

body {
	font-family: helvetica, arial, sans-serif;
}

h1 {
	color: #3a241d;
	text-align: center;
}

इस तरीके से टैग को स्टाइल करना आपको यूनिक एलिमेंट्स पर नियंत्रण देता है, लेकिन आपको अपने टेरारियम में कई पौधों के स्टाइल्स को नियंत्रित करने की आवश्यकता है। ऐसा करने के लिए, आपको CSS सेलेक्टर्स का उपयोग करना होगा।

Ids

बाएं और दाएं कंटेनर्स को लेआउट करने के लिए कुछ स्टाइल जोड़ें। चूंकि केवल एक बायां कंटेनर और केवल एक दायां कंटेनर है, उन्हें मार्कअप में ids दिए गए हैं। उन्हें स्टाइल करने के लिए, # का उपयोग करें:

#left-container {
	background-color: #eee;
	width: 15%;
	left: 0px;
	top: 0px;
	position: absolute;
	height: 100%;
	padding: 10px;
}

#right-container {
	background-color: #eee;
	width: 15%;
	right: 0px;
	top: 0px;
	position: absolute;
	height: 100%;
	padding: 10px;
}

यहां, आपने इन कंटेनर्स को स्क्रीन के बाएं और दाएं किनारे पर बिल्कुल पोजिशनिंग के साथ रखा है, और उनकी चौड़ाई के लिए प्रतिशत का उपयोग किया है ताकि वे छोटे मोबाइल स्क्रीन के लिए स्केल कर सकें।

यह कोड काफी दोहराया गया है, इसलिए यह "DRY" (Don't Repeat Yourself) नहीं है; क्या आप इन ids को स्टाइल करने का एक बेहतर तरीका ढूंढ सकते हैं, शायद एक id और एक class के साथ? आपको मार्कअप बदलने और CSS को रिफैक्टर करने की आवश्यकता होगी:

<div id="left-container" class="container"></div>

क्लासेस

ऊपर के उदाहरण में, आपने स्क्रीन पर दो यूनिक एलिमेंट्स को स्टाइल किया। यदि आप स्क्रीन पर कई एलिमेंट्स पर स्टाइल लागू करना चाहते हैं, तो आप CSS क्लासेस का उपयोग कर सकते हैं। ऐसा करें ताकि बाएं और दाएं कंटेनर्स में पौधों को लेआउट किया जा सके।

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

<div class="plant-holder">
	<img class="plant" alt="plant" id="plant1" src="./images/plant1.png" />
</div>

अपने style.css फाइल में निम्नलिखित जोड़ें:

.plant-holder {
	position: relative;
	height: 13%;
	left: -10px;
}

.plant {
	position: absolute;
	max-width: 150%;
	max-height: 150%;
	z-index: 2;
}

इस स्निपेट में उल्लेखनीय है रिलेटिव और एब्सोल्यूट पोजिशनिंग का मिश्रण, जिसे हम अगले सेक्शन में कवर करेंगे। ऊंचाई को प्रतिशत द्वारा संभालने के तरीके पर ध्यान दें:

आपने पौधे होल्डर की ऊंचाई को 13% पर सेट किया है, एक अच्छा नंबर यह सुनिश्चित करने के लिए कि सभी पौधे प्रत्येक वर्टिकल कंटेनर में बिना स्क्रॉलिंग की आवश्यकता के प्रदर्शित हों।

आपने पौधे होल्डर को बाईं ओर स्थानांतरित किया ताकि पौधे अपने कंटेनर के भीतर अधिक केंद्रित हो सकें। छवियों में एक बड़ी मात्रा में पारदर्शी बैकग्राउंड है ताकि उन्हें अधिक ड्रैग करने योग्य बनाया जा सके, इसलिए स्क्रीन पर बेहतर फिट होने के लिए उन्हें बाईं ओर धकेलने की आवश्यकता है।

फिर, पौधे को 150% की अधिकतम चौड़ाई दी गई है। यह ब्राउज़र के स्केल डाउन होने पर इसे स्केल डाउन करने की अनुमति देता है। अपने ब्राउज़र का आकार बदलने का प्रयास करें; पौधे अपने कंटेनर्स में रहते हैं लेकिन फिट होने के लिए स्केल डाउन करते हैं।

इसके अलावा उल्लेखनीय है z-index का उपयोग, जो एक एलिमेंट की सापेक्ष ऊंचाई को नियंत्रित करता है (ताकि पौधे कंटेनर के ऊपर बैठें और टेरारियम के अंदर बैठते हुए दिखाई दें)।

आपको पौधे होल्डर और पौधे CSS सेलेक्टर दोनों की आवश्यकता क्यों है?

CSS पोजिशनिंग

पोजिशन प्रॉपर्टीज (जैसे static, relative, fixed, absolute, और sticky पोजिशन) को मिलाना थोड़ा मुश्किल हो सकता है, लेकिन जब सही तरीके से किया जाता है तो यह आपके पेज पर एलिमेंट्स पर अच्छा नियंत्रण देता है।

एब्सोल्यूट पोजिशन किए गए एलिमेंट्स को उनके निकटतम पोजिशन किए गए पूर्वजों के सापेक्ष पोजिशन किया जाता है, और यदि कोई नहीं है, तो इसे डॉक्यूमेंट बॉडी के अनुसार पोजिशन किया जाता है।

रिलेटिव पोजिशन किए गए एलिमेंट्स को उनके प्रारंभिक पोजिशन से दूर उनकी प्लेसमेंट को समायोजित करने के लिए CSS के निर्देशों के आधार पर पोजिशन किया जाता है।

हमारे उदाहरण में, plant-holder एक रिलेटिव-पोजिशन किया गया एलिमेंट है जो एक एब्सोल्यूट-पोजिशन किए गए कंटेनर के भीतर पोजिशन किया गया है। परिणामी व्यवहार यह है कि साइड बार कंटेनर्स बाएं और दाएं पिन किए गए हैं, और plant-holder नेस्टेड है, साइड बार्स के भीतर समायोजित हो रहा है, पौधों को एक वर्टिकल रो में रखने के लिए जगह दे रहा है।

plant स्वयं भी एब्सोल्यूट पोजिशनिंग का उपयोग करता है, इसे ड्रैग करने योग्य बनाने के लिए आवश्यक है, जैसा कि आप अगले पाठ में खोजेंगे।

साइड कंटेनर्स और plant-holder के पोजिशनिंग प्रकारों को स्विच करने के साथ प्रयोग करें। क्या होता है?

CSS लेआउट्स

अब आप जो सीखा है उसका उपयोग करके टेरारियम को पूरी तरह से CSS का उपयोग करके बनाएंगे!

पहले, .terrarium div बच्चों को CSS का उपयोग करके एक गोल आयत के रूप में स्टाइल करें:

.jar-walls {
	height: 80%;
	width: 60%;
	background: #d1e1df;
	border-radius: 1rem;
	position: absolute;
	bottom: 0.5%;
	left: 20%;
	opacity: 0.5;
	z-index: 1;
}

.jar-top {
	width: 50%;
	height: 5%;
	background: #d1e1df;
	position: absolute;
	bottom: 80.5%;
	left: 25%;
	opacity: 0.7;
	z-index: 1;
}

.jar-bottom {
	width: 50%;
	height: 1%;
	background: #d1e1df;
	position: absolute;
	bottom: 0%;
	left: 25%;
	opacity: 0.7;
}

.dirt {
	width: 60%;
	height: 5%;
	background: #3a241d;
	position: absolute;
	border-radius: 0 0 1rem 1rem;
	bottom: 1%;
	left: 20%;
	opacity: 0.7;
	z-index: -1;
}

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

हम rem का उपयोग कर रहे हैं बॉर्डर-रेडियस के लिए, एक फॉन्ट-सापेक्ष लंबाई। इस प्रकार की सापेक्ष माप के बारे में अधिक पढ़ें CSS स्पेसिफिकेशन में।

जार के रंग और अपारदर्शिता बनाम मिट्टी को बदलने का प्रयास करें। क्या होता है? क्यों?


🚀चुनौती

जार को अधिक ग्लास जैसा दिखाने के लिए बाईं ओर नीचे के क्षेत्र में 'बबल' चमक जोड़ें। आप .jar-glossy-long और .jar-glossy-short को एक प्रतिबिंबित चमक जैसा दिखाने के लिए स्टाइल करेंगे। यह इस तरह दिखेगा:

अंतिम टेरारियम

पोस्ट-लेक्चर क्विज़ पूरा करने के लिए, इस Learn मॉड्यूल से गुजरें: CSS के साथ अपने HTML ऐप को स्टाइल करें

पोस्ट-लेक्चर क्विज़

पोस्ट-लेक्चर क्विज़

समीक्षा और स्व-अध्ययन

CSS दिखने में सरल लगता है, लेकिन सभी ब्राउज़र्स और सभी स्क्रीन साइज के लिए ऐप को पूरी तरह से स्टाइल करने में कई चुनौतियां होती हैं। CSS-Grid और Flexbox ऐसे टूल्स हैं जो काम को थोड़ा अधिक संरचित और अधिक विश्वसनीय बनाने के लिए विकसित किए गए हैं। इन टूल्स के बारे में जानने के लिए Flexbox Froggy और Grid Garden खेलें।

असाइनमेंट

CSS रिफैक्टरिंग


अस्वीकरण:
यह दस्तावेज़ AI अनुवाद सेवा Co-op Translator का उपयोग करके अनुवादित किया गया है। जबकि हम सटीकता सुनिश्चित करने का प्रयास करते हैं, कृपया ध्यान दें कि स्वचालित अनुवाद में त्रुटियां या अशुद्धियां हो सकती हैं। मूल भाषा में उपलब्ध मूल दस्तावेज़ को प्रामाणिक स्रोत माना जाना चाहिए। महत्वपूर्ण जानकारी के लिए, पेशेवर मानव अनुवाद की सिफारिश की जाती है। इस अनुवाद के उपयोग से उत्पन्न किसी भी गलतफहमी या गलत व्याख्या के लिए हम जिम्मेदार नहीं हैं।