|
|
1 month ago | |
|---|---|---|
| .. | ||
| README.md | 1 month ago | |
| assignment.md | 1 month ago | |
README.md
JavaScript बेसिक्स: मेथड्स और फंक्शन्स
स्केचनोट द्वारा Tomomi Imura
journey
title आपकी JavaScript फ़ंक्शन यात्रा
section आधार
फ़ंक्शन सिंटैक्स: 5: You
फ़ंक्शन कॉल करना: 4: You
पैरामीटर और तर्क: 5: You
section उन्नत अवधारणाएं
रिटर्न मान: 4: You
डिफ़ॉल्ट पैरामीटर: 5: You
फ़ंक्शन संयोजन: 4: You
section आधुनिक JavaScript
एरो फ़ंक्शन: 5: You
गुमनाम फ़ंक्शन: 4: You
उच्च-क्रम फ़ंक्शन: 5: You
प्री-लेक्चर क्विज़
एक ही कोड को बार-बार लिखना प्रोग्रामिंग की सबसे आम निराशाओं में से एक है। फंक्शन्स इस समस्या को हल करते हैं क्योंकि ये आपको कोड को पुन: प्रयोज्य ब्लॉकों में पैकेज करने देते हैं। फंक्शन्स को ऐसे सोचें जैसे कि वे मानकीकृत भाग हैं जिन्होंने हेनरी फोर्ड की असेम्बली लाइन क्रांतिकारी बना दी – एक बार जब आप एक विश्वसनीय कंपोनेंट बनाते हैं, तो आप इसे जरूरत के अनुसार कहीं भी बिना फिर से बनाये उपयोग कर सकते हैं।
फंक्शन्स आपको कोड के टुकड़ों को बंडल करने देते हैं ताकि आप उन्हें अपने प्रोग्राम में हर जगह पुनः उपयोग कर सकें। हर जगह एक ही लॉजिक को कॉपी और पेस्ट करने के बजाय, आप एक बार फंक्शन बना सकते हैं और जब भी जरूरत हो उसे कॉल कर सकते हैं। यह तरीका आपके कोड को व्यवस्थित रखता है और अपडेट करना कहीं ज्यादा आसान बनाता है।
इस पाठ में, आप सीखेंगे कि खुद के फंक्शन्स कैसे बनाएं, उनमें जानकारी कैसे पास करें, और उपयोगी परिणाम कैसे वापस प्राप्त करें। आप फंक्शन्स और मेथड्स के बीच का फर्क समझेंगे, आधुनिक सिंटैक्स के तरीकों को जानेंगे, और देखेंगे कि फंक्शन्स एक दूसरे के साथ कैसे काम कर सकते हैं। हम इन अवधारणाओं को चरण-दर-चरण बनाएंगे।
🎥 ऊपर की छवि पर क्लिक करें मेथड्स और फंक्शन्स पर एक वीडियो के लिए।
आप यह पाठ Microsoft Learn पर भी ले सकते हैं!
mindmap
root((JavaScript Functions))
Basic Concepts
Declaration
पारंपरिक सिंटैक्स
एरो फ़ंक्शन सिंटैक्स
Calling
ब्रैकेट का उपयोग करना
ब्रैकेट आवश्यक हैं
Parameters
इनपुट मान
कई पैरामीटर
डिफ़ॉल्ट मान
Arguments
पास किए गए मान
कोई भी प्रकार हो सकता है
Return Values
आउटपुट डेटा
return स्टेटमेंट
फ़ंक्शन से बाहर निकलें
Use Results
वेरिएबल में स्टोर करें
चेन फ़ंक्शन
Advanced Patterns
उच्च-स्तरीय
पैरामीटर के रूप में फ़ंक्शन
कॉलबैक
Anonymous
नाम की आवश्यकता नहीं
इनलाइन परिभाषा
फंक्शन्स
एक फंक्शन एक स्व-निहित कोड का ब्लॉक होता है जो एक विशिष्ट कार्य करता है। यह उस लॉजिक को समेटे रखता है जिसे आप जब भी जरूरत हो चला सकते हैं।
अपने प्रोग्राम में एक ही कोड को कई बार लिखने के बजाय, आप उसे एक फंक्शन में पैकेज कर सकते हैं और जब भी जरूरत हो उस फंक्शन को कॉल कर सकते हैं। यह तरीका आपके कोड को साफ सुथरा रखता है और अपडेट करना कहीं आसान बना देता है। सोचिए अगर आपको अपनी कोडबेस के 20 अलग-अलग स्थानों पर फैले लॉजिक को बदलना पड़े तो कितना चुनौतीपूर्ण होगा।
अपने फंक्शन्स को स्पष्ट नाम देना जरूरी है। एक अच्छा नामित फंक्शन अपने उद्देश्य को स्पष्ट रूप से संप्रेषित करता है – जब आप cancelTimer() देखते हैं, तो आप तुरंत समझ जाते हैं कि यह क्या करता है, ठीक उसी तरह जैसे एक स्पष्ट लेबल वाला बटन आपको बताता है कि क्लिक करने पर क्या होगा।
फंक्शन बनाना और कॉल करना
आइए देखें कि फंक्शन कैसे बनाते हैं। इसका सिंटैक्स एक समान पैटर्न का पालन करता है:
function nameOfFunction() { // फ़ंक्शन परिभाषा
// फ़ंक्शन परिभाषा/शरीर
}
इसे तोड़कर समझें:
functionकीवर्ड जावास्क्रिप्ट को बताता है "अरे, मैं एक फंक्शन बना रहा हूँ!"nameOfFunctionवह जगह है जहाँ आप अपने फंक्शन को एक वर्णनात्मक नाम देते हैं- कर्कश ब्रैकेट्स
()उन पैरामीटर को दर्शाते हैं जहाँ आप पैरामीटर जोड़ सकते हैं (हम जल्द ही इस पर आएंगे) - घुंघराले ब्रैकेट्स
{}वे कोड होते हैं जो आप कॉल करने पर चलते हैं
आइए एक साधारण अभिवादन फंक्शन बनाकर इसे देखें:
function displayGreeting() {
console.log('Hello, world!');
}
यह फंक्शन कंसोल पर "Hello, world!" प्रिंट करता है। एक बार परिभाषित होने के बाद, आप इसे जरूरत के अनुसार कई बार उपयोग कर सकते हैं।
अपने फंक्शन को चलाने (या "कॉल" करने) के लिए, उसका नाम लिखें और उसके बाद पैरेंथेसिस लगाएं। जावास्क्रिप्ट आपको अपने फंक्शन को पहले या बाद में परिभाषित करने की अनुमति देता है – जावास्क्रिप्ट इंजन निष्पादन क्रम को संभालेगा।
// हमारे फ़ंक्शन को कॉल करना
displayGreeting();
जब आप यह लाइन चलाते हैं, तो यह आपके displayGreeting फंक्शन के अंदर सभी कोड को निष्पादित करता है, जो आपके ब्राउज़र के कंसोल में "Hello, world!" प्रदर्शित करता है। आप इस फंक्शन को कई बार कॉल कर सकते हैं।
🧠 फंक्शन मूल बातें जांच: अपने पहले फंक्शन्स बनाना
आइए देखें कि आप बेसिक फंक्शन्स के बारे में कैसा महसूस कर रहे हैं:
- फंक्शन परिभाषाओं में
{}कर्कश ब्रैकेट्स का उपयोग क्यों करते हैं? - क्या होगा अगर आप
displayGreetingको बिना पैरेंथेसिस के लिखें? - आप एक ही फंक्शन को कई बार क्यों कॉल करना चाहेंगे?
flowchart TD
A["✏️ फ़ंक्शन परिभाषित करें"] --> B["📦 कोड पैकेज करें"]
B --> C["🏷️ इसे एक नाम दें"]
C --> D["📞 आवश्यकता होने पर कॉल करें"]
D --> E["🔄 कहीं भी पुन: उपयोग करें"]
F["💡 लाभ"] --> F1["कोड पुनरावृत्ति नहीं"]
F --> F2["रखरखाव में आसान"]
F --> F3["स्पष्ट संगठन"]
F --> F4["परीक्षण में आसान"]
style A fill:#e3f2fd
style E fill:#e8f5e8
style F fill:#fff3e0
ध्यान दें: आपने इन पाठों में मेथड्स का उपयोग किया है।
console.log()एक मेथड है – मूलतःconsoleऑब्जेक्ट से संबंधित एक फंक्शन। मुख्य अंतर यह है कि मेथड्स ऑब्जेक्ट्स से जुड़े होते हैं, जबकि फंक्शन्स स्वतंत्र होते हैं। कई डेवलपर्स ये शब्द सामान्य बातचीत में समानार्थक रूप से उपयोग करते हैं।
फंक्शन सर्वश्रेष्ठ प्रथाएं
यहाँ कुछ सुझाव हैं जो आपको बेहतर फंक्शन्स लिखने में मदद करेंगे:
- अपने फंक्शन्स को स्पष्ट, वर्णनात्मक नाम दें – आपका भविष्य का खुद आप इसका आभार मानेंगे!
- यदि नाम कई शब्दों का हो तो camelCasing का उपयोग करें (जैसे
calculateTotalबजायcalculate_total) - हर फंक्शन को एक काम करने पर केन्द्रित रखें
फंक्शन को जानकारी भेजना
हमारा displayGreeting फंक्शन सीमित है – यह हर किसी के लिए सिर्फ "Hello, world!" दिखा सकता है। पैरामीटर हमें फंक्शन्स को अधिक लचीला और उपयोगी बनाना संभव करते हैं।
पैरामीटर ऐसे प्लेसहोल्डर्स की तरह होते हैं जहाँ आप अलग-अलग कॉल पर विभिन्न मान डाल सकते हैं। इस तरह, एक ही फंक्शन हर कॉल पर अलग-अलग जानकारी के साथ काम कर सकता है।
जब आप फंक्शन को परिभाषित करते हैं तो पैरेंथेसिस के अंदर पैरामीटर लिखते हैं, और यदि एक से अधिक हैं तो उन्हें कॉमा से अलग करते हैं:
function name(param, param2, param3) {
}
प्रत्येक पैरामीटर एक प्लेसहोल्डर की तरह कार्य करता है – जब कोई आपका फंक्शन कॉल करता है, तो वे वास्तविक मान प्रदान करते हैं जो इन स्थानों पर डाले जाते हैं।
आइए हमारा ग्रीटिंग फंक्शन अपडेट करें ताकि वह किसी के नाम को स्वीकार कर सके:
function displayGreeting(name) {
const message = `Hello, ${name}!`;
console.log(message);
}
ध्यान दें कि हम बैकटिक्स (`) और ${} का उपयोग कर रहे हैं ताकि नाम सीधे संदेश में डाला जा सके – इसे टेम्पलेट लिटरल कहा जाता है, और यह स्ट्रिंग्स को वेरिएबल के साथ जोड़ने का एक बहुत सुविधाजनक तरीका है।
अब जब हम फंक्शन को कॉल करते हैं, तो हम कोई भी नाम पास कर सकते हैं:
displayGreeting('Christopher');
// चलाने पर "नमस्ते, क्रिस्टोफ़र!" दिखाता है
जावास्क्रिप्ट स्ट्रिंग 'Christopher' को name पैरामीटर में असाइन कर देता है, और वैयक्तिकृत संदेश "Hello, Christopher!" बनाता है।
flowchart LR
A["🎯 फ़ंक्शन कॉल"] --> B["📥 पैरामीटर"]
B --> C["⚙️ फ़ंक्शन बॉडी"]
C --> D["📤 परिणाम"]
A1["displayGreeting('Alice')"] --> A
B1["name = 'Alice'"] --> B
C1["टेम्प्लेट लिटरल\n\`नमस्ते, \${name}!\`"] --> C
D1["'नमस्ते, Alice!'"] --> D
E["🔄 पैरामीटर प्रकार"] --> E1["स्ट्रिंग्स"]
E --> E2["संख्या"]
E --> E3["बूलियन"]
E --> E4["ऑब्जेक्ट्स"]
E --> E5["फ़ंक्शन"]
style A fill:#e3f2fd
style C fill:#e8f5e8
style D fill:#fff3e0
style E fill:#f3e5f5
डिफ़ॉल्ट मान
अगर हम कुछ पैरामीटर को वैकल्पिक बनाना चाहें तो क्या होगा? तब डिफ़ॉल्ट मान काम आते हैं!
मान लीजिए हम चाहते हैं कि लोग ग्रीटिंग शब्द को कस्टमाइज़ कर सकें, लेकिन अगर वे इसे निर्दिष्ट न करें तो हम "Hello" को बैकअप के रूप में उपयोग करेंगे। आप डिफ़ॉल्ट मान इस तरह सेट कर सकते हैं जैसे आप कोई वैरिएबल सेट करते हैं:
function displayGreeting(name, salutation='Hello') {
console.log(`${salutation}, ${name}`);
}
यहाँ, name अभी भी आवश्यक है, लेकिन salutation के पास 'Hello' का बैकअप मान है यदि कोई अलग ग्रीटिंग निर्दिष्ट न करे।
अब हम इस फंक्शन को दो अलग-अलग तरीकों से कॉल कर सकते हैं:
displayGreeting('Christopher');
// "Hello, Christopher" प्रदर्शित करता है
displayGreeting('Christopher', 'Hi');
// "Hi, Christopher" प्रदर्शित करता है
पहली कॉल में, जावास्क्रिप्ट डिफ़ॉल्ट "Hello" का उपयोग करता है क्योंकि हमने कोई सल्यूटेशन नहीं दिया। दूसरी कॉल में, यह हमारे कस्टम "Hi" का उपयोग करता है। यह लचीलापन फंक्शन्स को विभिन्न स्थितियों के लिए उपयुक्त बनाता है।
🎛️ पैरामीटर मास्टरी चेक: फंक्शन्स को लचीला बनाना
अपने पैरामीटर समझ को जांचें:
- पैरामीटर और आर्ग्यूमेंट में क्या अंतर है?
- डिफ़ॉल्ट मान वास्तविक प्रोग्रामिंग में क्यों उपयोगी हैं?
- क्या आप अनुमान लगा सकते हैं कि अगर आप पैरामीटर से ज्यादा आर्ग्यूमेंट पास करें तो क्या होगा?
stateDiagram-v2
[*] --> NoParams: function greet() {}
[*] --> WithParams: function greet(name) {}
[*] --> WithDefaults: function greet(name, greeting='Hi') {}
NoParams --> Static: हमेशा एक जैसा आउटपुट
WithParams --> Dynamic: इनपुट के साथ बदलता है
WithDefaults --> Flexible: वैकल्पिक अनुकूलन
Static --> [*]
Dynamic --> [*]
Flexible --> [*]
note right of WithDefaults
सबसे लचीला तरीका
पिछड़े अनुकूल
end note
पेशेवर सुझाव: डिफ़ॉल्ट पैरामीटर आपके फंक्शन्स को अधिक उपयोगकर्ता-मित्रवत बनाते हैं। उपयोगकर्ता जल्दी शुरुआत कर सकते हैं समझदारी से सेट किये डिफ़ॉल्ट्स के साथ, लेकिन जरूरत पड़ने पर कस्टमाइज़ भी कर सकते हैं!
रिटर्न मान
अब तक हमारे फंक्शन्स ने केवल कंसोल पर संदेश प्रिंट किए हैं, लेकिन अगर आप चाहते हैं कि फंक्शन कुछ कैलकुलेट करे और परिणाम वापस दे?
यही जगह है जहां रिटर्न मान आते हैं। सिर्फ कुछ दिखाने की बजाय, फंक्शन एक मान वापस कर सकता है जिसे आप किसी वैरिएबल में स्टोर कर सकते हैं या अपने कोड के अन्य भागों में उपयोग कर सकते हैं।
मान वापस भेजने के लिए, आप return कीवर्ड का उपयोग करते हैं जिसके बाद आप जो भी वापस करना चाहते हैं वह लिखते हैं:
return myVariable;
यहाँ एक महत्वपूर्ण बात है: जब फंक्शन को return स्टेटमेंट मिलता है, तो वह तुरंत रुक जाता है और वह मान वापस भेज देता है जिसे कॉल किया था।
आइए हमारा ग्रीटिंग फंक्शन इस तरह संशोधित करें कि वह संदेश प्रिंट करने के बजाय वापस करे:
function createGreetingMessage(name) {
const message = `Hello, ${name}`;
return message;
}
अब यह फंक्शन ग्रीटिंग प्रिंट करने के बजाय संदेश बनाता है और हमें वापस देता है।
वापस प्राप्त मान को उपयोग करने के लिए, हम इसे किसी वैरिएबल में स्टोर कर सकते हैं जैसे किसी अन्य मान को करते हैं:
const greetingMessage = createGreetingMessage('Christopher');
अब greetingMessage में "Hello, Christopher" है और हम इसे कहीं भी अपने कोड में उपयोग कर सकते हैं – वेबपेज पर दिखाने, ईमेल में शामिल करने, या किसी अन्य फंक्शन को पास करने के लिए।
flowchart TD
A["🔧 फ़ंक्शन प्रसंस्करण"] --> B{"रिटर्न स्टेटमेंट?"}
B -->|हाँ| C["📤 मान लौटाएँ"]
B -->|नहीं| D["📭 अपरिभाषित लौटाएँ"]
C --> E["💾 चर में संग्रहित करें"]
C --> F["🔗 अभिव्यक्ति में उपयोग करें"]
C --> G["📞 फ़ंक्शन को पास करें"]
D --> H["⚠️ आमतौर पर उपयोगी नहीं"]
I["📋 लौटाए गए मान के उपयोग"] --> I1["परिणाम की गणना करें"]
I --> I2["इनपुट मान्य करें"]
I --> I3["डेटा परिवर्तित करें"]
I --> I4["ऑब्जेक्ट बनाएं"]
style C fill:#e8f5e8
style D fill:#ffebee
style I fill:#e3f2fd
🔄 रिटर्न मान जांच: परिणाम प्राप्त करना
अपने रिटर्न मान की समझ का मूल्यांकन करें:
- फंक्शन में
returnस्टेटमेंट के बाद कोड क्या होता है? - केवल कंसोल पर प्रिंट करने से बेहतर रिटर्न मान क्यों होता है?
- क्या एक फंक्शन विभिन्न प्रकार के मान (string, number, boolean) वापस कर सकता है?
pie title "सामान्य रिटर्न मान प्रकार"
"स्ट्रिंग्स" : 30
"संख्याएँ" : 25
"ऑब्जेक्ट्स" : 20
"बूलियंस" : 15
"ऐरेज़" : 10
मुख्य अंतर्दृष्टि: जो फंक्शन्स मान वापस करते हैं वे अधिक बहुमुखी होते हैं क्योंकि कॉल करने वाला तय करता है कि परिणाम के साथ क्या करना है। इससे आपका कोड अधिक मॉड्यूलर और पुनः उपयोग योग्य बनता है!
फंक्शन्स को पैरामीटर के रूप में पास करना
फंक्शन्स को अन्य फंक्शन्स के पैरामीटर के रूप में पास किया जा सकता है। यह अवधारणा शुरू में जटिल लग सकती है, लेकिन यह एक शक्तिशाली फीचर है जो लचीली प्रोग्रामिंग पैटर्न सक्षम बनाता है।
यह पैटर्न बहुत सामान्य है जब आप कहना चाहते हैं "जब कुछ हो, तो यह अन्य काम करो।" उदाहरण के लिए, "जब टाइमर खत्म हो जाए, तब यह कोड चलाओ" या "जब उपयोगकर्ता बटन क्लिक करे, तब यह फंक्शन कॉल करो।"
आइए setTimeout देखें, जो एक बिल्ट-इन फंक्शन है जो कुछ समय इंतजार करता है और फिर कुछ कोड चलता है। हमें इसे बताना होता है कि कौन सा कोड चलाना है – फंक्शन पास करने के लिए यह एक बेहतरीन इस्तेमाल है!
यह कोड आज़माएँ – 3 सेकंड बाद आपको एक संदेश दिखेगा:
function displayDone() {
console.log('3 seconds has elapsed');
}
// टाइमर मान मिलीसेकंड में है
setTimeout(displayDone, 3000);
ध्यान दें कि हम displayDone (पैरेंथेसिस के बिना) setTimeout को पास कर रहे हैं। हम खुद फंक्शन को कॉल नहीं कर रहे हैं – हम इसे setTimeout के हाथ दे रहे हैं और कह रहे हैं "इसे 3 सेकंड में कॉल करना।"
अनाम फंक्शन्स
कभी-कभी आपको बस एक ही काम के लिए फंक्शन चाहिए और आप उसे नाम देना नहीं चाहते। सोचिए – अगर आप फंक्शन को केवल एक बार उपयोग कर रहे हैं, तो क्यों अपने कोड को एक अतिरिक्त नाम से भरें?
जावास्क्रिप्ट आपको अनाम फंक्शन्स बनाने देता है – नामहीन फंक्शन्स जिन्हें आप ठीक वहीं परिभाषित कर सकते हैं जहाँ आपको जरूरत हो।
यहाँ हमारा टाइमर उदाहरण अनाम फंक्शन का उपयोग कर कैसे दिखेगा:
setTimeout(function() {
console.log('3 seconds has elapsed');
}, 3000);
यह वही परिणाम प्राप्त करता है, लेकिन फंक्शन setTimeout कॉल के भीतर सीधे परिभाषित होता है, जिससे अलग फंक्शन डिक्लेरेशन की जरूरत खत्म हो जाती है।
फैट ऐरो फंक्शन्स
आधुनिक जावास्क्रिप्ट में फंक्शन्स लिखने का एक और भी छोटा तरीका है जिसे ऐरो फंक्शन्स कहते हैं। वे => का उपयोग करते हैं (जो एक तीर की तरह दिखता है – समझे?) और डेवलपर्स के बीच बहुत लोकप्रिय हैं।
ऐरो फंक्शन्स आपको function कीवर्ड को छोड़कर अधिक संक्षिप्त कोड लिखने देते हैं।
यहाँ हमारा टाइमर उदाहरण ऐरो फंक्शन के साथ है:
setTimeout(() => {
console.log('3 seconds has elapsed');
}, 3000);
() वह जगह है जहाँ पैरामीटर होंगे (यहाँ खाली है), फिर ऐरो => आता है, और अंत में फंक्शन शरीर घुंघराले ब्रैकेट्स में। यह समान कार्यक्षमता अधिक संक्षिप्त सिंटैक्स के साथ प्रदान करता है।
flowchart LR
A["📝 फ़ंक्शन शैलियाँ"] --> B["पारंपरिक"]
A --> C["एरो"]
A --> D["गुमनाम"]
B --> B1["function name() {}"]
B --> B2["उठाया हुआ"]
B --> B3["नामित"]
C --> C1["const name = () => {}"]
C --> C2["संक्षिप्त सिंटैक्स"]
C --> C3["आधुनिक शैली"]
D --> D1["function() {}"]
D --> D2["कोई नाम नहीं"]
D --> D3["एक बार उपयोग"]
E["⏰ उपयोग कब करें"] --> E1["पारंपरिक: पुन: उपयोग योग्य फ़ंक्शन"]
E --> E2["एरो: छोटे कॉलबैक"]
E --> E3["गुमनाम: ईवेंट हैंडलर"]
style A fill:#e3f2fd
style B fill:#e8f5e8
style C fill:#fff3e0
style D fill:#f3e5f5
style E fill:#e0f2f1
कब कौन सी रणनीति का उपयोग करें
आप कब किस approach का उपयोग करें? एक व्यावहारिक गाइडलाइन: यदि आप फंक्शन को कई बार उपयोग करेंगे तो इसे नाम दें और अलग से परिभाषित करें। यदि यह किसी एक विशेष उपयोग के लिए है, तो अनाम फंक्शन पर विचार करें। ऐरो फंक्शन्स और पारंपरिक सिंटैक्स दोनों वैध विकल्प हैं, हालांकि आधुनिक जावास्क्रिप्ट कोडबेस में ऐरो फंक्शन्स अधिक प्रचलित हैं।
🎨 फंक्शन स्टाइल मास्टरी चेक: सही सिंटैक्स चुनना
अपने सिंटैक्स ज्ञान को जांचें:
- आप कब पारंपरिक फंक्शन सिंटैक्स की तुलना में ऐरो फंक्शन्स को प्राथमिकता देंगे?
- अनाम फंक्शन्स का मुख्य लाभ क्या है?
- क्या आप ऐसी स्थिति सोच सकते हैं जहाँ नामित फंक्शन अनाम फंक्शन से बेहतर हो?
quadrantChart
title फ़ंक्शन विकल्प निर्णय मैट्रिक्स
x-axis सरल --> जटिल
y-axis एक बार उपयोग --> पुन: प्रयोज्य
quadrant-1 एरो फ़ंक्शंस
quadrant-2 नामित फ़ंक्शंस
quadrant-3 अनाम फ़ंक्शंस
quadrant-4 पारंपरिक फ़ंक्शंस
Event Handlers: [0.3, 0.2]
Utility Functions: [0.7, 0.8]
Callbacks: [0.2, 0.3]
Class Methods: [0.8, 0.7]
Mathematical Operations: [0.4, 0.6]
आधुनिक प्रवृत्ति: संक्षिप्त सिंटैक्स के कारण कई डेवलपर्स के लिए ऐरो फंक्शन्स डिफ़ॉल्ट विकल्प बन रहे हैं, लेकिन पारंपरिक फंक्शन्स अभी भी अपने स्थान पर हैं!
🚀 चुनौती
क्या आप एक वाक्य में फंक्शन्स और मेथड्स के बीच का अंतर स्पष्ट कर सकते हैं? इसे आज़माएं!
GitHub Copilot एजेंट चुनौती 🚀
एजेंट मोड का उपयोग करके निम्नलिखित चुनौती पूरा करें:
विवरण: एक उपयोगिता लाइब्रेरी बनाएं जो इस पाठ में कवर किए गए विभिन्न फंक्शन कॉन्सेप्ट्स जैसे पैरामीटर, डिफ़ॉल्ट मान, रिटर्न मान, और ऐरो फंक्शन्स को प्रदर्शित करती हो।
प्रांप्ट: एक जावास्क्रिप्ट फाइल mathUtils.js बनाएं जिसमें निम्नलिखित फंक्शन्स हों:
- एक फंक्शन
addजो दो पैरामीटर ले और उनका योग वापस करे - एक फंक्शन
multiplyजिसमें डिफ़ॉल्ट पैरामीटर मान हों (दूसरा पैरामीटर डिफ़ॉल्ट 1) - एक ऐरो फंक्शन
squareजो एक नंबर ले और उसका वर्ग वापस करे - एक फंक्शन
calculateजो एक अन्य फंक्शन को पैरामीटर के रूप में स्वीकार करे और दो नंबर, फिर उस फंक्शन को उन नंबरों पर लागू करे - उपयुक्त टेस्ट केस के साथ प्रत्येक फंक्शन को कॉल करना प्रदर्शित करें
एजेंट मोड के बारे में अधिक जानने के लिए यहाँ देखें।
पोस्ट-लेक्चर क्विज़
समीक्षा और आत्म-अध्ययन
यह थोड़ा और पढ़ने लायक है कि ऐरो फंक्शन्स के बारे में क्योंकि इन्हें कोड बेस में बढ़ चढ़ कर उपयोग किया जा रहा है। फंक्शन्स लिखने का अभ्यास करें, और फिर इसे नए सिंटैक्स के साथ दोबारा लिखें।
असाइनमेंट
🧰 आपका JavaScript फंक्शन्स टूलकिट सारांश
graph TD
A["🎯 जावास्क्रिप्ट फ़ंक्शन"] --> B["📋 फ़ंक्शन घोषणा"]
A --> C["📥 पैरामीटर"]
A --> D["📤 रिटर्न मान"]
A --> E["🎨 आधुनिक सिंटैक्स"]
B --> B1["function name() {}"]
B --> B2["वर्णनात्मक नामकरण"]
B --> B3["पुन: प्रयोज्य कोड ब्लॉक"]
C --> C1["इनपुट डेटा"]
C --> C2["डिफ़ॉल्ट मान"]
C --> C3["कई पैरामीटर"]
D --> D1["return बयान"]
D --> D2["फ़ंक्शन से बाहर निकलें"]
D --> D3["डेटा वापस पास करें"]
E --> E1["एरो फ़ंक्शन: () =>"]
E --> E2["गुमनाम फ़ंक्शन"]
E --> E3["हायर-ऑर्डर फ़ंक्शन"]
F["⚡ मुख्य लाभ"] --> F1["कोड पुन: प्रयोज्यता"]
F --> F2["बेहतर संगठन"]
F --> F3["सरल परीक्षण"]
F --> F4["मॉड्यूलर डिज़ाइन"]
style A fill:#e3f2fd
style B fill:#e8f5e8
style C fill:#fff3e0
style D fill:#f3e5f5
style E fill:#e0f2f1
style F fill:#fce4ec
🚀 आपकी JavaScript फंक्शन्स मास्टरी टाइमलाइन
⚡ आप अगले 5 मिनट में क्या कर सकते हैं
- एक साधारण फंक्शन लिखें जो आपका पसंदीदा नंबर वापस करता हो
- दो पैरामीटर वाला एक फंक्शन बनाएं जो उन्हें जोड़ता हो
- पारंपरिक फ़ंक्शन को तीर फ़ंक्शन सिंटैक्स में बदलने का प्रयास करें
- चुनौती का अभ्यास करें: फ़ंक्शन और मेथड के बीच का अंतर समझाएं
🎯 इस घंटे में आप क्या हासिल कर सकते हैं
- पोस्ट-लीसन क्विज़ पूरा करें और किसी भी भ्रमित करने वाली अवधारणाओं की समीक्षा करें
- GitHub Copilot चुनौती से गणित यूटिलिटीज़ लाइब्रेरी बनाएं
- एक ऐसा फ़ंक्शन बनाएं जो पैरामीटर के रूप में एक अन्य फ़ंक्शन का उपयोग करता हो
- डिफ़ॉल्ट पैरामीटर के साथ फ़ंक्शन लिखने का अभ्यास करें
- फ़ंक्शन रिटर्न वैल्यूज़ में टेम्पलेट लिटरेक्स के साथ प्रयोग करें
📅 आपका सप्ताह भर का फ़ंक्शन मास्टरी
- "फ़नों के साथ मज़ा" असाइनमेंट को रचनात्मकता के साथ पूरा करें
- कुछ दोहराए जाने वाले कोड को पुनःप्रयोग योग्य फ़ंक्शनों में सुधारें
- केवल फ़ंक्शनों का उपयोग करके एक छोटा कैलकुलेटर बनाएं (कोई ग्लोबल वेरिएबल नहीं)
map()औरfilter()जैसे एरे मेथड्स के साथ तीर फ़ंक्शनों का अभ्यास करें- आम कार्यों के लिए उपयोगिता फ़ंक्शनों का संग्रह बनाएं
- उच्च-स्तरीय फ़ंक्शनों और फ़ंक्शनल प्रोग्रामिंग अवधारणाओं का अध्ययन करें
🌟 आपका महीने भर का परिवर्तन
- क्लोज़र और स्कोप जैसे उन्नत फ़ंक्शन अवधारणाओं में महारत हासिल करें
- एक ऐसा प्रोजेक्ट बनाएं जो फ़ंक्शन कम्पोज़िशन का भारी उपयोग करता हो
- फ़ंक्शन दस्तावेज़ीकरण को बेहतर करके ओपन सोर्स में योगदान दें
- किसी और को फ़ंक्शन्स और विभिन्न सिंटैक्स शैलियों के बारे में सिखाएं
- जावास्क्रिप्ट में फ़ंक्शनल प्रोग्रामिंग तरीके खोजें
- भविष्य के प्रोजेक्ट्स के लिए पुनःप्रयोग योग्य फ़ंक्शनों की व्यक्तिगत लाइब्रेरी बनाएं
🏆 अंतिम फ़ंक्शन्स चैंपियन चेक-इन
अपनी फ़ंक्शन मास्टरी का जश्न मनाएं:
- अब तक आपने सबसे उपयोगी फ़ंक्शन कौन सा बनाया है?
- फ़ंक्शन्स के बारे में सीखने से आपने कोड संगठन के बारे में अपना दृष्टिकोण कैसे बदला है?
- आप कौन सी फ़ंक्शन सिंटैक्स पसंद करते हैं और क्यों?
- आप कौन सा वास्तविक दुनिया का समस्या फ़ंक्शन लिखकर हल करेंगे?
journey
title आपकी फ़ंक्शन आत्मविश्वास विकास
section आज
सिंटैक्स से भ्रमित: 3: You
मूल बातें समझना: 4: You
सरल फ़ंक्शन लिखना: 5: You
section इस सप्ताह
पैरामीटर का उपयोग: 4: You
मान वापस करना: 5: You
आधुनिक सिंटैक्स: 5: You
section अगला महीना
फ़ंक्शन संयोजन: 5: You
उन्नत पैटर्न: 5: You
दूसरों को सिखाना: 5: You
🎉 आपने प्रोग्रामिंग की सबसे शक्तिशाली अवधारणाओं में से एक में महारत हासिल कर ली है! फ़ंक्शन्स बड़े प्रोग्रामों के बिल्डिंग ब्लॉक्स होते हैं। हर एप्लिकेशन जिसे आप कभी बनाएंगे वह कोड को व्यवस्थित, पुनः उपयोग करने योग्य और संरचित करने के लिए फ़ंक्शन्स का उपयोग करेगा। अब आप लॉजिक को पुनः उपयोग योग्य घटकों में पैकेज करना समझते हैं, जिससे आप एक अधिक कुशल और प्रभावी प्रोग्रामर बन गए हैं। मॉड्यूलर प्रोग्रामिंग की दुनिया में आपका स्वागत है! 🚀
अस्वीकरण: इस दस्तावेज़ का अनुवाद एआई अनुवाद सेवा Co-op Translator का उपयोग करके किया गया है। जबकि हम सटीकता के लिए प्रयास करते हैं, कृपया ध्यान दें कि स्वचालित अनुवादों में त्रुटियाँ या अशुद्धियाँ हो सकती हैं। मूल दस्तावेज़ अपनी मूल भाषा में प्राधिकारी स्रोत माना जाना चाहिए। महत्वपूर्ण जानकारी के लिए, पेशेवर मानव अनुवाद की सलाह दी जाती है। इस अनुवाद के उपयोग से उत्पन्न किसी भी गलतफ़हमी या गलत व्याख्या के लिए हम उत्तरदायी नहीं हैं।

