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/ne/2-js-basics/2-functions-methods/README.md

20 KiB

जाभास्क्रिप्ट आधारभूत: मेथड्स र फङ्सन्स

JavaScript Basics - Functions

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

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

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

जब हामी कोड लेख्ने कुरा सोच्छौं, हाम्रो कोड पढ्न सजिलो बनाउनु महत्त्वपूर्ण हुन्छ। यो अलि अचम्म लाग्न सक्छ, तर कोड लेखिएको भन्दा धेरै पटक पढिन्छ। डेभलपरको टूलबक्समा कोडलाई व्यवस्थित र सजिलो बनाउनको लागि एउटा मुख्य उपकरण भनेको फङ्सन हो।

Methods and Functions

🎥 माथिको तस्बिरमा क्लिक गरेर मेथड्स र फङ्सन्सको बारेमा भिडियो हेर्नुहोस्।

तपाईं यो पाठ Microsoft Learn मा लिन सक्नुहुन्छ!

फङ्सन्स

फङ्सन भनेको मुख्य रूपमा कोडको एउटा ब्लक हो, जसलाई हामी आवश्यक पर्दा चलाउन सक्छौं। यो त्यस्ता अवस्थामा उपयोगी हुन्छ, जहाँ एउटै काम बारम्बार गर्नुपर्छ। एउटै तर्कलाई धेरै ठाउँमा दोहोर्याउनुको सट्टा (जसले पछि अपडेट गर्न गाह्रो बनाउँछ), हामी यसलाई एउटै ठाउँमा राख्न सक्छौं र आवश्यक पर्दा चलाउन सक्छौं। तपाईंले फङ्सनलाई अर्को फङ्सनबाट पनि बोलाउन सक्नुहुन्छ!

फङ्सनलाई नाम दिन सक्ने क्षमता पनि उत्तिकै महत्त्वपूर्ण छ। यो सामान्य लाग्न सक्छ, तर नामले कोडको भागलाई छिटो बुझ्न मद्दत गर्छ। यसलाई बटनमा लेबल जस्तै सोच्न सकिन्छ। यदि मैले "Cancel timer" लेखिएको बटन क्लिक गरेँ भने, मलाई थाहा हुन्छ यसले घडी रोक्छ।

फङ्सन बनाउने र बोलाउने

फङ्सनको सिंट्याक्स यस प्रकार देखिन्छ:

function nameOfFunction() { // function definition
 // function definition/body
}

यदि मैले अभिवादन देखाउने फङ्सन बनाउन चाहें भने, यो यसरी देखिन सक्छ:

function displayGreeting() {
  console.log('Hello, world!');
}

जब हामी हाम्रो फङ्सनलाई बोलाउन चाहन्छौं, हामी फङ्सनको नाम पछाडि () प्रयोग गर्छौं। हाम्रो फङ्सनलाई बोलाउनु अघि वा पछि परिभाषित गर्न सकिन्छ; जाभास्क्रिप्ट कम्पाइलरले यसलाई खोज्छ।

// calling our function
displayGreeting();

NOTE: एउटा विशेष प्रकारको फङ्सनलाई मेथड भनिन्छ, जुन तपाईंले पहिले नै प्रयोग गरिरहनुभएको छ! वास्तवमा, हामीले माथिको डेमोमा console.log प्रयोग गर्दा यो देख्यौं। मेथड र फङ्सनको फरक के हो भने, मेथड कुनै वस्तु (हाम्रो उदाहरणमा console) मा जोडिएको हुन्छ, जबकि फङ्सन स्वतन्त्र हुन्छ। धेरै डेभलपरहरूले यी दुई शब्दलाई परस्पर प्रयोग गर्छन्।

फङ्सन बनाउँदा ध्यान दिनुपर्ने कुराहरू

फङ्सन बनाउँदा ध्यान दिनुपर्ने केही महत्त्वपूर्ण कुराहरू:

  • सधैं वर्णनात्मक नामहरू प्रयोग गर्नुहोस् ताकि फङ्सनले के गर्छ भन्ने थाहा होस्।
  • शब्दहरू जोड्न camelCasing प्रयोग गर्नुहोस्।
  • फङ्सनलाई विशेष काममा केन्द्रित राख्नुहोस्।

फङ्सनमा जानकारी पठाउने

फङ्सनलाई अझ उपयोगी बनाउन, तपाईंले प्रायः यसमा जानकारी पठाउन चाहनुहुन्छ। यदि हामीले माथिको displayGreeting उदाहरणलाई विचार गर्यौं भने, यसले केवल Hello, world! देखाउँछ। यो धेरै उपयोगी फङ्सन होइन। यदि हामी यसलाई अलि लचिलो बनाउन चाहन्छौं, जस्तै अभिवादन गर्ने व्यक्तिको नाम निर्दिष्ट गर्न दिनु, हामी parameter थप्न सक्छौं।

प्यारामिटरहरू परिभाषा भागमा कोष्ठकभित्र सूचीबद्ध गरिन्छ र कमाले छुट्याइन्छ:

function name(param, param2, param3) {

}

हामी हाम्रो displayGreeting लाई नाम स्वीकार गर्न र देखाउन अद्यावधिक गर्न सक्छौं।

function displayGreeting(name) {
  const message = `Hello, ${name}!`;
  console.log(message);
}

जब हामी हाम्रो फङ्सनलाई बोलाउन र प्यारामिटर पठाउन चाहन्छौं, हामी यसलाई कोष्ठकभित्र निर्दिष्ट गर्छौं।

displayGreeting('Christopher');
// displays "Hello, Christopher!" when run

डिफल्ट मानहरू

हामी हाम्रो फङ्सनलाई अझ लचिलो बनाउन थप प्यारामिटरहरू थप्न सक्छौं। तर यदि हामी चाहँदैनौं कि प्रत्येक मान अनिवार्य होस् भने के गर्ने? हाम्रो अभिवादन उदाहरणलाई ध्यानमा राख्दै, हामी नामलाई अनिवार्य राख्न सक्छौं (हामीलाई कसलाई अभिवादन गर्ने थाहा हुनुपर्छ), तर हामी चाहन्छौं कि अभिवादनलाई इच्छानुसार अनुकूलित गर्न सकियोस्। यदि कसैले यसलाई अनुकूलित गर्न चाहँदैन भने, हामी डिफल्ट मान प्रदान गर्छौं। प्यारामिटरलाई डिफल्ट मान प्रदान गर्न, हामी यसलाई भेरिएबलको मान सेट गरेजस्तै सेट गर्छौं - parameterName = 'defaultValue'। पूरा उदाहरण हेर्नुहोस्:

function displayGreeting(name, salutation='Hello') {
  console.log(`${salutation}, ${name}`);
}

जब हामी फङ्सनलाई बोलाउँछौं, हामी salutation को लागि मान सेट गर्ने निर्णय गर्न सक्छौं।

displayGreeting('Christopher');
// displays "Hello, Christopher"

displayGreeting('Christopher', 'Hi');
// displays "Hi, Christopher"

रिटर्न मानहरू

अहिलेसम्म हामीले बनाएको फङ्सनले सधैं console मा आउटपुट गर्छ। कहिलेकाहीं यो ठीक हुन्छ, विशेष गरी जब हामीले अन्य सेवाहरूलाई बोलाउने फङ्सनहरू बनाउँछौं। तर यदि मैले गणना गर्न र मानलाई अन्यत्र प्रयोग गर्नको लागि सहायक फङ्सन बनाउन चाहें भने के गर्ने?

हामी यो रिटर्न मान प्रयोग गरेर गर्न सक्छौं। रिटर्न मान फङ्सनबाट फर्काइन्छ, र यसलाई स्ट्रिङ वा नम्बर जस्तै स्थिर मानमा भण्डारण गर्न सकिन्छ।

यदि फङ्सनले केही फर्काउँछ भने return कीवर्ड प्रयोग गरिन्छ। return कीवर्डले फर्काइने मान वा सन्दर्भको अपेक्षा गर्छ:

return myVariable;

हामी अभिवादन सन्देश बनाउन र मानलाई कलरलाई फर्काउन फङ्सन बनाउन सक्छौं।

function createGreetingMessage(name) {
  const message = `Hello, ${name}`;
  return message;
}

जब हामी यो फङ्सनलाई बोलाउँछौं, हामी मानलाई भेरिएबलमा भण्डारण गर्छौं। यो स्थिर मान सेट गरेजस्तै हो (जस्तै const name = 'Christopher')।

const greetingMessage = createGreetingMessage('Christopher');

फङ्सनलाई फङ्सनको प्यारामिटरको रूपमा प्रयोग गर्ने

जब तपाईं आफ्नो प्रोग्रामिङ करियरमा अगाडि बढ्नुहुन्छ, तपाईंले फङ्सनलाई फङ्सनको प्यारामिटरको रूपमा स्वीकार गर्ने फङ्सनहरू देख्नुहुनेछ। यो चतुर तरिका प्रायः त्यतिबेला प्रयोग गरिन्छ जब हामीलाई थाहा हुँदैन कि केही कहिले हुनेछ वा पूरा हुनेछ, तर हामीलाई थाहा छ कि प्रतिक्रिया स्वरूप कुनै अपरेसन गर्नुपर्छ।

उदाहरणको लागि, setTimeout लाई विचार गर्नुहोस्, जसले टाइमर सुरु गर्छ र पूरा भएपछि कोड कार्यान्वयन गर्छ। हामीले यसलाई कुन कोड कार्यान्वयन गर्न चाहन्छौं भन्ने बताउनुपर्छ। यो काम फङ्सनको लागि उपयुक्त छ!

यदि तपाईं तलको कोड चलाउनुहुन्छ भने, ३ सेकेन्डपछि तपाईंले 3 seconds has elapsed सन्देश देख्नुहुनेछ।

function displayDone() {
  console.log('3 seconds has elapsed');
}
// timer value is in milliseconds
setTimeout(displayDone, 3000);

अनाम फङ्सनहरू

हामीले बनाएको कुरालाई फेरि हेरौं। हामी एउटा नाम भएको फङ्सन बनाउँदैछौं, जुन केवल एक पटक प्रयोग हुनेछ। हाम्रो एप्लिकेसन जति जटिल बन्छ, हामीले धेरै फङ्सनहरू बनाउँदैछौं, जुन केवल एक पटक बोलाइनेछ। यो आदर्श होइन। वास्तवमा, हामीले सधैं नाम दिन आवश्यक छैन!

जब हामी फङ्सनलाई प्यारामिटरको रूपमा पास गर्दैछौं, हामी यसलाई पहिले बनाउने प्रक्रियालाई बाइपास गर्न सक्छौं र यसको सट्टा प्यारामिटरको रूपमा बनाउँछौं। हामी function कीवर्ड प्रयोग गर्छौं, तर यसलाई प्यारामिटरको रूपमा बनाउँछौं।

हामीले माथिको कोडलाई अनाम फङ्सन प्रयोग गरेर पुनःलेखन गरौं:

setTimeout(function() {
  console.log('3 seconds has elapsed');
}, 3000);

यदि तपाईं हाम्रो नयाँ कोड चलाउनुहुन्छ भने, तपाईंले उस्तै नतिजा पाउनुहुनेछ। हामीले फङ्सन बनायौं, तर यसलाई नाम दिनुपरेन!

फ्याट एरो फङ्सनहरू

धेरै प्रोग्रामिङ भाषाहरू (जाभास्क्रिप्ट सहित) मा सामान्य शर्टकट भनेको एरो वा फ्याट एरो फङ्सन प्रयोग गर्ने क्षमता हो। यसले => भन्ने विशेष संकेतक प्रयोग गर्छ, जुन एरो जस्तो देखिन्छ - त्यसैले नाम! => प्रयोग गरेर, हामी function कीवर्डलाई स्किप गर्न सक्छौं।

हामीले हाम्रो कोडलाई फ्याट एरो फङ्सन प्रयोग गरेर फेरि लेखौं:

setTimeout(() => {
  console.log('3 seconds has elapsed');
}, 3000);

प्रत्येक रणनीति कहिले प्रयोग गर्ने

अब तपाईंले फङ्सनलाई प्यारामिटरको रूपमा पास गर्न तीन तरिकाहरू देख्नुभयो र सोच्न सक्नुहुन्छ कि कुन बेला कुन प्रयोग गर्ने। यदि तपाईंलाई थाहा छ कि तपाईंले फङ्सनलाई एकभन्दा बढी पटक प्रयोग गर्नुहुनेछ भने, यसलाई सामान्य रूपमा बनाउनुहोस्। यदि तपाईंले यसलाई केवल एक स्थानको लागि प्रयोग गर्नुहुनेछ भने, सामान्यतया अनाम फङ्सन प्रयोग गर्नु राम्रो हुन्छ। फ्याट एरो फङ्सन वा परम्परागत function सिंट्याक्स प्रयोग गर्ने निर्णय तपाईंको हो, तर तपाईंले देख्नुहुनेछ कि अधिकांश आधुनिक डेभलपरहरूले => लाई प्राथमिकता दिन्छन्।


🚀 चुनौती

के तपाईं एक वाक्यमा फङ्सन र मेथडको बीचको फरक स्पष्ट गर्न सक्नुहुन्छ? प्रयास गर्नुहोस्!

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

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

समीक्षा र आत्म-अध्ययन

एरो फङ्सनहरूको बारेमा थप पढ्न लायक छ, किनभने यी कोड बेसहरूमा बढ्दो रूपमा प्रयोग गरिन्छ। एउटा फङ्सन लेख्ने अभ्यास गर्नुहोस्, र त्यसपछि यसलाई यो सिंट्याक्स प्रयोग गरेर पुनःलेखन गर्नुहोस्।

असाइनमेन्ट

फन विथ फङ्सन्स

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