Unlimited Wordpress themes, plugins, graphics & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Web Design
  2. Navigation Design
Webdesign

ओरमैन क्लार्क की वर्टीकल नेविगेशन मेनू: CSS अनुवाद

by
Difficulty:IntermediateLength:LongLanguages:
This post is part of a series called Bringing Premium Pixels to Life.
Orman Clark's Chunky 3D Web Buttons: The CSS3 Version
Quick Tip: Give Orman's Navigation the :target Treatment

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

ऑरमैन क्लार्क की कोडित PSD श्रृंखला में अगला उसके अद्भुत दिखते Vertical Navigation Menu है। संभव है कि हम इमेजेज के न्यूनतम मात्रा का उपयोग करते हुए इसे CSS3 और jQuery के साथ पुन: बनाएँ।

केवल उन इमेजेज को हम आइकॉन के लिए उपयोग कर रहे हैं - मैं SpriteRight नामक एक नए उपकरण का उपयोग कर एक स्प्राइट का निर्माण करूँगा, लेकिन यह वैकल्पिक है। इसके अतिरिक्त, मैं अपनी CSS3 के ग्रेडियेंट बनाने के लिए GradientApp का उपयोग कर रहा हूं, लेकिन फिर यह वैकल्पिक है।


Step 1: मूल HTML मार्कअप

आइए कुछ बुनियादी मार्कअप शुरू करें, एक खाली HTML5 डॉक्यूमेंट:

और अब हमारे मेनू के लिए मार्कअप; युक्त आवरण के भीतर एक unordered list।

अन्त में, हम अपने मौजूदा सूची आइटमों में से प्रत्येक के अंदर स्थित एक unordered list डालकर submenus बनाते हैं।

ठीक है, वहाँ बहुत सारे लग सकते हैं लेकिन इसे आप को भ्रमित न करें। सबसे पहले हमने पांच सूची आइटमों के साथ एक unordered list बनाई है, प्रत्येक में anchor tag के अंदर। फिर हमने नेस्टेड unordered lists, प्रत्येक तीन सूची आइटमों के साथ जोड़ दी हैं।

मैंने प्रत्येक सूची आइटम के लिए एक class भी जोड़ा है, बस यह स्टाइल को बाद में आसान बना देगा। अंत में, संख्याओं के लिए हमने प्रत्येक anchor tag के अंदर एक span tag बनाया है। यदि आप इसे अपने ब्राउज़र में देखते हैं तो इसे इस तरह दिखना चाहिए:

Basic markup

Step 2: द्रव फ़ॉन्ट्स

हम पहले सुनिश्चित करेंगे कि हमारे मेनू सही ढंग से प्रदर्शित हो। इन नियमों को css/styles.css में जोड़ें, वे हमारे सभी ul s के margin और padding को 0 पर सेट करेंगे, और सूची स्टाइल को हटा दें।

हमारे मेनू स्टाइल करना शुरू करने से पहले हम एक निश्चित चौड़ाई और 13px के एक font-size (em यूनिट्स में व्यक्त) के साथ एक रेपर बनाएंगे। सबसे पहले हम शरीर को एक नियम जोड़ देंगे, font-size:100% ;। यह सुनिश्चित करेगा कि हमारा स्टाइल ब्राउज़र डिफ़ॉल्ट font-size (आमतौर पर 16px) पर आधारित है।

अब यह समझाने के लिए कि रैपर font-size कैसे कार्य करता है। हमें इसे em के रूप में व्यक्त करना है; अपने पैरेंट के font-size के साइज के आनुपातिक। हम 13px के लिए लक्ष्य कर रहे हैं, इसलिए पैरेंट के साइज को 16px मानते हुए, हमारा परिणामी 13 /16 = 0.8125 है। 13px है 0.8125 * 16px।

यूनिट्स में हमारे फोंट (और अन्य तत्व) को मापने से उन्हें द्रव बना दिया जाएगा। अब अगर हम रैपर फ़ॉन्ट साइज (या हमारे ब्राउज़र डिफ़ॉल्ट साइज) को बदलते हैं तो पूरे मेनू उस बेस के संबंध में समायोजित होगा। यह आपको भ्रमित करने की कोशिश न करें, अगर आपको अपने फोंट को बदलने में मदद की ज़रूरत है तो मेरा सुझाव है कि आप pxtoem.com पर जाएं।

हमने आवरण को 220px की एक निश्चित चौड़ाई दी है और इसे मार्जिन जोड़कर कुछ शीर्ष के साथ केंद्रित किया है margin:100px auto;


Step 3: मुख्य मेनू CSS

आगे हम मेनू के लिए कुछ स्टाइल जोड़ देंगे। हम मेनू ul auto की चौड़ाई और ऊंचाई बनाते हैं, फिर पूरी चीज़ की छाया लागू करें। ऊंचाई को ऑटो के रूप में जोड़कर, स्लाइडर खुलने पर छाया एडजस्ट हो जाएगी।

फिर एंकर टैग; हम 100% की चौड़ाई जोड़ देंगे जिसका मतलब है कि वे आवरण के 220px चौड़ाई तक फैले होंगे। ऊंचाई के लिए हम ems का उपयोग करेंगे, तो हमारे मुख्य फ़ॉन्ट-आकार 13px के बारे में सोचें। हमारा.psd 36px की ऊंचाई दर्शाता है, इसलिए हमारा लक्ष्य है। हम 36 ले लेंगे और इसे 13 से विभाजित करेंगे जो लगभग 2.75em (36 / 13 = 2.76923077) के लिए बाहर आता है। हम रेखा की ऊंचाई (सभी टेक्स्ट को लंबवत केन्द्रित करने के लिए) के लिए 2.75em का भी इस्तेमाल करेंगे, फिर टेक्स्ट को पुश करने के लिए कुछ टेक्स्ट-इंडेंट लागू करें, बाद में हमारे आइकन के लिए जगह बनाये।

हम बैकग्राउंड के लिए एक CSS3 के ग्रेडिएंट को जोड़ देंगे, मैंने आगे बढ़कर GradientApp के साथ इसे बनाया था। इसके बाद हम फ़ॉन्ट को बदल देंगे, हम एक टेक्स्ट छाया के साथ Helvetica Neue font और एक सफ़ेद रंग लागू करेंगे। ध्यान दें कि हमने यहां एक फ़ॉन्ट-साइज का उपयोग नहीं किया था। ऐसा इसलिए है क्योंकि हमारे बेस फ़ॉन्ट 13px के आवरण के लिए है जो हमारे एंकर को विरासत में मिला है, इसलिए इसे इसमें जोड़ने की कोई आवश्यकता नहीं है।

ठीक है! अब यह बेहतर दिखना शुरू कर रहा है और हमें कुछ संरचना भी मिल रही है! लेकिन कैसे हम एक बैकग्राउंड रंग जोड़ते हैं, ताकि मेनू बेहतर तरीके से खड़ा होगा ..

Step 2

टिप: EMs याद रखना

ऊपर CSS से आप देख सकते हैं कि यह भूलना आसान है कि आपकी यूनिट्स का वास्तव में क्या अर्थ है। आपके मूल गणना की टिप्पणियां छोड़ना एक अच्छा विचार है, ताकि जब आप भविष्य में अपने कोड पर वापस आएं, तो आप अभी भी जो भी हो रहा है उसका पता चल सकता है। सूत्र को याद रखें: desired px / parent px = resultant em और अनुमानित प्रतीक (≈) का उपयोग करें यदि आप परिणाम को गोल कर रहे हैं।


Step 4: सबमेनु CSS

सफेद सबमेनु के लिए कुछ CSS जोड़ने का समय। हमें कुछ ग्रे सीमाओं के साथ एक सफेद बैकग्राउंड जोड़ने की आवश्यकता होगी। आखिरी बार के लिए नोटिस में इसकी कोई सीमा नहीं है, इसलिए हम उसे इसे हटाने के लिए :last-child भाषण चयनकर्ता के साथ लक्षित करेंगे। इसमें एक गहरे नीले रंग का बॉर्डर है, इसलिए हम भूरे रंग को हटा दें, नीले रंग का एक जोड़ दें।

अगला कदम पिछले के समान होगा; हम ऊंचाई और चौड़ाई को फिर से जोड़ देंगे, हम बैकग्राउंड को सफेद रंग में बदल देंगे। इस बार हमें फॉण्ट-साइज बदलने की आवश्यकता है। हम 12px के लिए लक्ष्य कर रहे हैं, ताकि desired px / parent px = resultant em  हमारे परिणाम की गणना कर सकें हम उन्हें 0.923em।

चलिए टेक्स्ट रंग को ग्रे में भी बदलते हैं। ध्यान दें हमने display:block। अगर हम float:left का इस्तेमाल करते हैं मेनू छोड़कर आसानी से चेतन नहीं होता, इसलिए हम डिस्प्ले ब्लॉक का इस्तेमाल करते हैं ताकि उन्हें अच्छी और आसानी से स्थानांतरित किया जा सके। आप यह भी देखेंगे कि हमने एक अतिरिक्त स्टाइल जोड़ दी है; हम इसे sub-ul के आखिरी चाइल्ड के लिए आवेदन कर रहे हैं। हमें ऐसा करने की आवश्यकता है ताकि हम सीमा रंग को बदल सकें।

अब यह वाकई अच्छा दिखना शुरू कर रहा है!

Step 3

Step 5: होवर और सक्रिय स्टाइलिंग

हम अब कुछ हॉवर और सक्रिय स्टाइलिंग को जोड़ देंगे, विशेष रूप से जब एॉर्डियनियन खुले हैं! हम सक्रिय मेनू में एक सीमा नीचे भी जोड़ देंगे। अब अगर आप सोच रहे हैं, "हमने एक सक्रिय class क्यों नहीं जोड़ी?" अच्छी तरह से मेरे दोस्त, यह है कि jQuery के बाद में क्या हो रहा है।


Step 6: मुख्य मेनू प्रतीक

हम छद्म से :before आइकन का उपयोग करके जोड़ देंगे। पहले हम सभी sub-ul एंकर टैग को लक्षित करेंगे, हम बैकग्राउंड स्प्राइट को लागू करेंगे और इसे दोहराने के लिए नहीं सेट करेंगे। हम इसे 36px का फॉण्ट-साइज देंगे, हालांकि कोई टेक्स्ट नहीं है; हम 36px का उपयोग करेंगे ताकि हम 1 के चौड़ाई और ऊंचाई का उपयोग कर सकें जो अब 36px के बराबर होगा। तब हम तत्व को 50% नीचे धकेल देंगे और इसे बीच में ऊपर से 5 सेंटीमीटर से हटा दें।

प्रत्येक sub-ul सूची आइटम के लिए classes का उपयोग करके, हम उन्हें लक्षित करेंगे और उन्हें स्प्राइट के लिए उचित बैकग्राउंड की स्थिति देंगे।

नोट: मै स्प्राइट के साथ बेला बनाना चाहता हूँ, तो मैंने स्प्राइटराइट नामक नये ऐप का उपयोग करके इस स्प्राइट को बनाया है, मैंने स्रोत फ़ाइलों में इमेजेज और प्रोजेक्ट फ़ाइलों को शामिल किया है।

Step 5

Step 7: मुख्य मेनू नंबर

ठीक है, उन स्पेन्स को याद रखें जो हमने जोड़ा? ये नंबर बनाएंगे!

सबसे पहले हम 11px का एक फ़ॉन्ट-आकार जोड़ देंगे (जो मोटे तौर पर 0.857em में परिवर्तित होता है)। हम उन्हें पूरी तरह से स्थान देंगे, और उन्हें दाहिनी ओर से 1 em तक धक्का देंगे, एक बार फिर - इस तरल पदार्थ को बनाने के लिए। हम इसे ऊपर से 50% नीचे धक्का देंगे और मार्जिन-टॉप को केंद्र से निकाल देंगे। एक बैकग्राउंड कुछ बॉक्स छाया, एक इंसेट और एक के साथ जोड़ दिया जाएगा।

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

Step 6

Step 8: सबमेनु अंक और एरो

यह प्रक्रिया पिछले स्टेप के समान होगी, इसलिए मैं ज्यादा विस्तार में नहीं जाऊंगा। यहां मुख्य अंतर हैं कि मैंने बैकग्राउंड का रंग हटा दिया है, सीमा बदल दी है और फ़ॉन्ट रंग बदल दिया है। हमें उस एरो को भी जोड़ना होगा और एक बार फिर से दुबला होगा: psuedo से :before। हम एक चौड़ाई और ऊंचाई को परिभाषित करते हैं और यह सुनिश्चित करने के लिए कि यह द्रव है, ems का उपयोग करते हुए कुछ बाएं पोजीशनिंग को जोड़ते हैं।

अन्त में, एक हॉवर स्टेट (उन टिप्पणियों के लिए धन्यवाद जिन्होंने अपनी प्रारंभिक अनुपस्थिति को बताया)। हम केवल एक गहरे रंग (#32373D) एंकर टेक्स्ट सूडो  एरो और अवधि के भीतर संख्या को लागू करते हैं।

तो यह अब बहुत अच्छा लग रहा है सही है? मुझे लगता है कि हम इस समय कुछ कार्यक्षमता जोड़ चुके हैं!

Step 7

Step 9: jQuery का समय

क्या आप यहाँ पाने के लिए इंतजार कर रहे हैं ?! ठीक है हम अंत में jQuery के बिंदु पर हैं। हमें पहली बार Google द्वारा होस्ट किए गए एक का उपयोग करके, jQuery पुस्तकालय से लिंक करना होगा। वर्तमान नवीनतम अनुवाद 1.7.1 है। अपने HTML पृष्ठ के मुख्य भाग में निम्नलिखित को जोड़ें:

अब समापन </body> टैग से पहले अपने html डॉक्यूमेंट के निचले हिस्से में निम्नलिखित को जोड़ें। चिंता मत करो अगर यह भ्रामक दिखता है, तो मैं इसे एक मिनट में समझाऊंगा।

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

यह पेज लोड होने पर सभी सबमेनु छुपाएगा।

सबसे पहले हम इसे कुछ करने के लिए कहेंगे जब हम एक मुख्य मेनू के एंकर टैग पर क्लिक करेंगे।

यहां हम एंकर टैग को किसी भी लिंक का पालन करने या एड्रेस बार में पता बदलने से रोक रहे हैं। जैसे अगर आपने कभी '#' की एक लिंक के साथ एक एंकर टैग बनाया है, जब आप इसे क्लिक करते हैं, तो यह अब एड्रेस बार में दिखाई नहीं देगा। एंकर टैग मूलतः अक्षम हैं।

अब हम यह निर्देश देंगे कि यदि menu_a class 'सक्रिय' है, तो इसे हटा दें।

यहां हम '.filter' और '.visible' का उपयोग करते हैं यदि एक मेनू खुले है, तो उसे सामान्य की गति के साथ स्लाइड करें।

यदि मेनू बंद है, तो class 'active' जोड़ें (ताकि हम अच्छी CSS स्टाइल तक पहुंच सकें) और सामान्य की गति के साथ इसे नीचे स्लाइड करें।

अब, हमें हमारे सशर्त बयान के भाग के रूप में एक ELSE का उपयोग करने की आवश्यकता होगी। इसलिए, ELSE class को सक्रिय करता है, और इसे छुपाने के लिए मेनू को स्लाइड करें। यह सिर्फ इसलिए है कि पेज को पुनः लोड किए बिना हम किसी भी मेनू को कोड कर सकते हैं।

नोट: यदि आप स्लाइड की गति को बदलना चाहते हैं, तो सामान्य रूप से परिवर्तन करें, e.g. '500'। यह 500 मिलीसेकेंड पर स्लाइड करेगा।

यदि आप स्क्रैच से jQuery सीखने में दिलचस्पी रखते हैं, तो आपको अच्छी तरह से सलाह दी जानी चाहिए कि Learn jQuery in 30 Days का कोर्स ट्यूट्सप्लस डॉट कॉम से निःशुल्क सीखें।


निष्कर्ष

खैर हमने इसे अंत तक बनाया! हमने CSS3 और jQuery का इस्तेमाल करते हुए ऑर्मन के सुंदर वर्टीकल नेविगेशन मेनू को कोडित किया है! लक्ष्य को छद्म चयनकर्ता के साथ केवल CSS3 के साथ कैसे बना सकता है, इस पर एक त्वरित टिप के लिए बने रहें:

Final
Final large
#wrapper {width: 440px; font-size: 1em}

मुझे आशा है कि आपने इस ट्यूटोरियल का आनंद लिया होगा, पढ़ने के लिए धन्यवाद!

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.