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

एक मल्टी-स्टेप फ़ॉर्म इंटरफ़ेस बनाएं

by
Length:LongLanguages:

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

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

आज, हम एक मल्टी-पार्ट फॉर्म बनाने जा रहे हैं, जो वेलिडेशन और एनीमेशन के साथ पूर्ण है। हम बहुत सारी जमीन को कवर करेंगे, इसलिए तैयार हो जाएं!


फॉर्म उच्च स्तरीय सर्वश्रेष्ठ अभ्यास

फॉर्म इंटरफ़ेस डिज़ाइन प्रयोज्यता बाधाओं का मीनफील्ड (minefiled) है। इससे पहले कि हम शुरू करें, चलो कुछ फार्म बेस्ट प्रैक्टिस के बारे में बात करते हैं।

अपने यूज़र्स को बहुत मुश्किल सोच में नहीं डालें

आम तौर पर अद्वितीय संपर्कों (unique interaction) को प्रोत्साहित करने के लिए फार्म नहीं होते हैं। अच्छे फॉर्म स्पष्ट नेविगेशन तकनीक और पूर्ण पारदर्शिता प्रदान करते हैं। अच्छे फॉर्म्स को अच्छी तरह लेबल और नेविगेट करना आसान है।

बहुत फैंसी मत करो

यह महत्वपूर्ण है कि डिफ़ॉल्ट फॉर्म बेहेवियर से बहुत दूर नहीं हटें। कुछ standards हैं जो की फॉर्म्स के डिफ़ॉल्ट बेहेवियर के लिए आधार हैं। इन स्टैंडर्ड्स से deviation का उपयोग पहुंच पर नकारात्मक प्रभाव डाल सकता है, इसलिए जब संभव हो तो उन डिफ़ॉल्ट स्टाइल्स को बनाए रखने पर विचार करें।

याद रखें, यूजर रहते नहीं हैं

आपके फॉर्म के यूजर को रहने की ज़रूरत नहीं है। वे रहने के लिए चुनते हैं। फ़ॉर्म भरना एक काम है, इसलिए इसे आसान बनाएं। (यदि संभव हो, तो इसे मज़े करो!) यूजर को भ्रमित न करें या मांग न करें; इसके बजाए, फॉर्म से पूछ रहे सवालों के आसपास एक संवाद स्थापित करें। विनम्र रहें।

मल्टी-सेक्शन तकनीकों का उपयोग कब किया जाए

Multi-section फॉर्म निश्चित रूप से एक अच्छी तकनीक हैं, कभी-कभी "फ़ॉर्म को विभाजित करने से पहले कितने इनपुट लेते हैं" के लिए कोई भी जवाब नहीं है। इसके बजाय, हमेशा विचार करें कि फ़ॉर्म को अलग-अलग हिस्सों में विभाजित करना मदद करेगा या बाधित करेगा। दूसरे, विचार करें कि क्या यह इंटरेक्शन डिज़ाइन के अन्य पहलुओं की मदद करता है या बाधित करता है।

यदि आपके पास बहुत अलग सेक्शंस के साथ फॉर्म हैं, तो यह कई भागों में अलग करना सार्थक हो सकता है। चेकआउट प्रक्रिया इस का एक सामान्य उदाहरण है (व्यक्तिगत जानकारी, शिपिंग जानकारी, भुगतान की जानकारी, और कन्फर्मेशन बहुत अलग और आम तौर पर पर्याप्त वर्ग हैं।)


इंटरेक्शन की प्लानिंग

हम arbitrary फ़ील्ड्स के साथ एक signup फार्म बनाने जा रहे हैं। हमें यह जानने की जरूरत है कि हम वर्तमान में किस सेक्शन में हैं, इसलिए हमें फ़ॉर्म के शीर्ष पर एक इंडिकेटर की आवश्यकता होगी। हम अपने फार्म सेक्शंस को हॉरिजॉन्टल करना चाहते हैं, दाएं से बाएं ओर स्लाइडिंग करते हुए। इसे पूरा करने के लिए, हम एक सेक्शन "window" एलिमेंट के अंदर पूर्ण स्थिति रखने के लिए विभिन्न सेक्शन सेट कर देंगे। हम भी दो बटन चाहते हैं; एक सामान्य सबमिट बटन है दूसरा एक "next section" बटन है।


मार्कअप

यहां हमारा फ़ॉर्म है:

मार्कअप काफी सरल है, लेकिन इसके कुछ टुकड़ों के बारे में बात करते हैं।

  • Fieldsets: inputs के समूह के लिए fieldset एक सिमेंटिक एलिमेंट हैं; यह पूरी तरह से हमारी स्थिति में सूट करता है।
  • Classnames: jQuery Validate बिल्ट-इन टाइप को डिफाइन करने के लिए क्लासेज का प्रयोग करता है। हम एक मिनट में देखेंगे कि यह कैसे काम करता है।
  • फील्ड आरबिटरेरी हैं। हमने आसान formatting के लिए पैराग्राफ टैग में रेडियो इनपुट को लपेट लिया है।
  • सबमिट और next बटन: बटन की एक क्लास के साथ एंकर टैग का उपयोग अगले सेक्शन पर जाने के लिए किया जाएगा। सबमिट इनपुट जब जावास्क्रिप्ट के माध्यम से उचित होगा दिखाया जायेगा।

स्टाइल्स (कम-स्वाद वाले)

यह लंबा है, तैयार हो जाओ..

चलो स्टाइल्स के महत्वपूर्ण हिस्से के माध्यम से चलते हैं।

अवलोकन

यह फॉर्म एक विशिष्ट चौड़ाई पर सेट है, जो margin:0 auto के साथ केंद्रित है: फिर position:relative सेट है। इस पोजिशनिंग चाइल्ड एलिमेंट्स को absolutely place करने के लिए absolute positioning allow करती है, containing form के relation में। containing फ़ॉर्म में तीन प्राथमिक प्रकार के एलिमेंट्स होते हैं: सेक्शन टैब और fieldset "window", साथ ही साथ बटन।

सेक्शन टैब containing एलिमेंट के relative रखा जाता है, और एक नकारात्मक टॉप मार्जिन के साथ "pulled" होता है। हम एक समान मार्जिन बॉटम के साथ बाकी लेआउट पर प्रभाव के लिए कम्पेन्सेट करते हैं।

fieldset "window" को positioned absolute सेट किया जाता है, जो कि पैरेंट फॉर्म एलिमेंट के relative है। चौड़ाई और ऊंचाई दोनों 100% पर सेट हैं इस window का उद्देश्य एलिमेंट्स को होल्ड करना है, फिर उन्हें छिपाने के लिए जब वे किनारों के बाहर गिरते हैं overflow: hidden के साथ। हम इसे फ़ॉर्म पर नहीं कर सकते, क्योंकि हमें इंडिकेटर टैब को बनाए रखना हैं।

अंत में, बटन एलिमेंट (एक एंकर टैग और सबमिट इनपुट) को फ़ॉर्म के निचले दाएं कोने पर absolute positioned कर दिया जाता है, नीचे और दाएं से 20 पिक्सल ऑफसेट करते हुए। हमने हॉवर पर बैकग्राउंड को गहरा करने के लिए बटन एलिमेंट में एक सरल CSS transition भी जोड़ा है।

कुछ और नोट्स

  • फ़ील्डसेट्स position: absolute के रूप में सेट हैं: हमारे पास दो क्लासेज हैं दो स्टेट के लिए और डिफ़ॉल्ट स्टेट के लिए। डिफ़ॉल्ट स्टेट फ़ील्ड्सेट को बाईं तरफ खींचती है; .current क्लास फ़ील्ड्सेट को विज़िबल एरिया में ले जाती है, और अंत में .next क्लास फ़ील्ड्सेट को फॉर्म के दायीं ओर ले जाती है।
  • वर्तमान क्लास में 1 की एक opacity है; डिफ़ॉल्ट (और स्वाभाविक रूप से .next) में 0 की opacity है
  • हम साधारण css ट्रांजीशन के साथ इन क्लासेज के बीच fieldsets को एनिमेट करते हैं।
  • .error और.valid क्लासेज वेलिडेशन स्टाइल के साथ मदद करेंगे। हम गूगल वैबफोंट्स के माध्यम से उपयोग के लिए मुफ़्त रूप से उपलब्ध फ़ॉन्ट, Merriweather Sans का उपयोग कर रहे हैं।

जावास्क्रिप्ट

यहाँ वह हिस्सा है जो सभी इंटरेक्शन का काम करता है। कोड को देखने से पहले कुछ नोट्स: यह कोड jQuery और jQuery Validate पर निर्भर करता है। JQuery validate एक प्लगइन है जो बहुत लंबे समय से रहा है, और इसलिए हजारों लोगों द्वारा इसका परीक्षण और सिद्ध किया गया है।

हमारी मूलभूत रणनीति: फॉर्म के लिए कुछ वेलिडेशन नियम सेट करें, जिसमे टेलीफ़ोन नंबर की जांच करने के लिए कस्टम फ़ंक्शन शामिल है। हम चाहते हैं कि यूजर पहले समाप्त सेक्शंस के माध्यम से वापस नेविगेट करने में सक्षम हो। हम चाहते हैं कि वे अगले सेक्शन में जाने के लिए एन्टर बटन का इस्तेमाल कर सकें; हालांकि, हम यूज़र्स को उससे अगले सेक्शन तक आगे बढ़ने की अनुमति नहीं देना चाहते हैं जब तक कि पिछले सेक्शन पुरे नहीं हो जाते और वैलिड नहीं हो जाते।

यदि यूजर किसी टैब पर जो कम्पलीट किये टैब्स से आगे हैं क्लिक करने की कोशिश करता है, तो हम उस section से नेविगेट अवॉयड करना चाहते हैं।

हम स्टेट्स के बीच ट्रांजीशन के लिए क्लासेज (jQuery एनिमेशन के बजाय) पर भरोसा करना चाहते हैं।

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

तो, चलो एक एक टुकड़े पर चलते हैं।

यह फ़ंक्शन, jQuery Validate के लिए सेटअप फ़ंक्शन है। सबसे पहले, हम प्लगइन को कह रहे हैं साइनअप फॉर्म लें और इसके लिए वेलिडेशन लागू करें। यदि वेलिडेशन सफल हो जाता है, तो हम उस लेबल के लिए valid नाम की एक क्लास जोड़ते हैं जो इनपुट एलिमेंट के बाद वेलिडेशन प्लगइन जोड़ता होता है, और utf-8 चेकमार्क के साथ टेक्स्ट को बदलता है।

हम error कॉलबैक भी दर्ज कर रहे हैं, हालांकि हम वास्तव में इस फंक्शन में कुछ नहीं कर रहे हैं। फ़ंक्शन को रजिस्टर ना करने में ऐसा लगता है की एरर होने पर succes function कालबैक हो। हम onsubmit हुक को false सेट कर रहे हैं; ऐसा इसलिए है क्योंकि एंटर दबाने से फ़ॉर्म को आटोमेटिक रूप से सबमिट किया जाता है, जो डिफ़ॉल्ट रूप से इनवैलिड फ़ॉर्म सबमिशन को रोकने के लिए वेलिडेशन चलाता है। फ़ॉर्म के डिफ़ॉल्ट बिहेवियर को रोकना फॉर्म वेलिडेशन को रोकता नहीं है। नतीजा यह है कि "next" स्क्रीन पर फ़ील्ड पहले कभी भी सबमिट नहीं किए जाने के बावजूद वेलिडेशन errors दिखाती है।

यह फ़ंक्शन keyup इवेंट के लिए सुनता है, फॉर्म पर ट्रिगर होने वाले। अगर हिट दर्ज की गई key एंटर हो (key कोड 13), तो हम निम्नलिखित जांच करते हैं। यदि next बटन अभी भी दिखाई दे रहा है और वर्तमान सेक्शन वैलिड है, तो फॉर्म सबमिट करते समय एंटर key के डिफ़ॉल्ट बिहेवियर को रोकें, जो फॉर्म सबमिशन है।

इसके बाद हम nextSection() कॉल करें, जो कि अगले सेक्शन में फ़ॉर्म को अग्रिम करता है। यदि वर्तमान सेक्शन में कोई भी इनवैलिड इनपुट्स है, तो उन इनपुट की पहचान की जाती है और फ़ॉर्म अग्रिम नहीं होता है यदि अगला बटन दिखाई नहीं दे रहा है, तो इसका मतलब है कि हम अंतिम सेक्शन पर हैं (जो हम इसके बाद के फ़ंक्शन में देखेंगे) और हम डिफ़ॉल्ट बिहेवियर (फ़ॉर्म सबमिशन) होने की अनुमति देना चाहते हैं।

ये फंक्शन्स सरल हैं। यदि आप "next" id वाले बटन को दबाते हैं, तो हम अगले सेक्शन में आगे बढ़ना चाहते हैं। याद रखें nextSection() फ़ंक्शन फॉर्म वेलिडेशन के लिए सभी आवश्यक जांच करता है।

फ़ॉर्म की सबमिट इवेंट पर, हम फ़ॉर्म सबमिशन से बचना चाहते हैं यदि नेक्स्ट बटन दिखाई देता हैं या यदि मौजूदा फ़ील्ड्सेट अंतिम नहीं है।

GoToSection() फ़ंक्शन इस फॉर्म के नेविगेशन के पीछे का कार्यक्षेत्र है। यह सिंगल आर्गुमेंट लेता है - टारगेट नेविगेशन का इंडेक्स। फ़ंक्शन इंडेक्स पैरामीटर से पारित होने वाले इंडेक्स के साथ सभी फ़ील्ड्सेट को लेता है और current क्लास को निकालता है, और next क्लास जोड़ता है। यह फॉर्म के दायीं ओर एलिमेंट को धक्का देता है

अगला, हम पास किए गए इंडेक्स से काम इंडेक्स वाले सभी फील्डसेटस के मौजूदा current क्लास को निकाल देते हैं। इसके बाद, हम लिस्ट आइटम में passed इंडेक्स  के बराबर को चुनते हैं और current क्लास जोड़ते हैं।

इसके बाद हम अन्य सभी सिबलिंग lis में से current क्लास हटा देतें हैं। हम एक timeout सेट करते हैं, जिसके बाद हम next क्लास को निकालते हैं और current और active क्लास फ़ील्ड में इंडेक्स पैरामीटर के पास के सूचकांक के बराबर जोड़ देते हैं।

active क्लास हमें यह बताता है कि यूजर फिर से इस विशेष सेक्शन पर नेविगेट कर सकता है। यदि index पैरामीटर में पारित 3 है (अंतिम फ़ील्ड्सेट), तो हम next बटन को छिपा देते हैं और सबमिट बटन दिखाते हैं। अन्यथा, हम यह सुनिश्चित करना चाहते हैं कि next बटन दिखाई देगा और सबमिट बटन छुपा हुआ है। यह हमें सबमिट बटन छिपाने के लिए अनुमति देता है जब तक कि अंतिम फ़ील्ड्सेट दिखाई न दे।

NextSection() फ़ंक्शन मूलतः goToSection() फ़ंक्शन के आस-पास एक wrapper है। जब nextSection कॉल किया जाता है, तो एक साधारण जांच यह सुनिश्चित करने के लिए की जाती है कि हम अंतिम सेक्शन पर नहीं हैं। जब तक हम नहीं हैं, तब तक हम उस सेक्शन में जाते हैं जो एक current इंडेक्स के बराबर है, और एक जोड़कर।

हम लिस्ट आइटम पर क्लिक ईवेंट को सुन रहे हैं। यह फ़ंक्शन यह सुनिश्चित करता है कि लिस्ट आइटम में active क्लास है, जो यूजर को प्रारंभ में सभी पिछले सेक्शंस को पूरा करके उस फॉर्म के उस सेक्शन पर पहुंचने के बाद प्राप्त होता है। यदि लिस्ट आइटम में क्लास होती है, तो हम goToSection को कॉल करते हैं और उस लिस्ट आइटम के इंडेक्स में पास करते हैं। यदि यूजर किसी सेक्शन से संबंधित लिस्ट आइटम पर क्लिक करता है, जहाँ वे अभी तक पहुंच नहीं सकते हैं, ब्राउज़र उन्हें सूचित करने के लिए चेतावनी देता है कि आगे बढ़ने से पहले उन्हें पिछले सेक्शंस को पूरा करना होगा।

अंत में, हम jQuery Validate प्लगइन द्वारा निर्धारित मेथड जोड़ रहे हैं जो मैन्युअल रूप से एक इनपुट की जांच करता है। हम इस पर ज्यादा वक्त नहीं बिताएंगे, क्योंकि यह सटीक कार्यक्षमता Validate Documentation में पाई जा सकती है।

मूलतः, हम यह सुनिश्चित करने के लिए जांच करते हैं कि यूजर को फ़ोन फ़ील्ड में रखे जाने वाले टेक्स्ट को regex (नंबर्स और सिम्बल्स की लंबी स्ट्रिंग) से मेल खाती है। यदि ऐसा होता है, तो इनपुट मान्य है। अगर ऐसा नहीं होता है, तो इनपुट के बाद संदेश "Please specify a valid phone number" जोड़ा गया है। आप किसी भी प्रकार के इनपुट (इसे एक regex का उपयोग करने की जरूरत नहीं है) के लिए जांच करने के लिए इस एक ही फंक्शनलिटी का उपयोग कर सकते हैं।

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


निष्कर्ष

हमने एक ठोस फॉर्म इंटरैक्शन बनाने के लिए कुछ न्यूनतम जावास्क्रिप्ट के साथ सिमेंटिक HTML और सरल LESS इस्तेमाल किया है। इस फॉर्म का निर्माण करने के लिए इस्तेमाल किए जाने वाले तरीके, विशेष रूप से स्टेट पहचानने के लिए classnames का इस्तेमाल करते हैं और फ़ंक्शनैलिटी और एनिमेशन को परिभाषित करने के लिए लगभग किसी भी इंटरैक्टिव प्रोजेक्ट में उपयोग किया जा सकता है। समान फ़ंक्शनैलिटी का इस्तेमाल प्रदर्शन स्टेप - खेल, और जो कुछ भी सरल स्टेट-बेस्ड इंटरैक्शन पर निर्भर करता है, के लिए किया जा सकता है।

इस फॉर्म में आप और क्या करेंगे? यूज़र्स को और अधिक स्वाभाविक रूप से एक थकाऊ प्रक्रिया जैसे एक लंबी बहु-चरण फॉर्म में भरने के माध्यम से किस प्रकार इंटरेक्शन करने के लिए मिलते हैं? उन्हें कमेंट में साझा करें!

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.