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

208 lines
20 KiB

<!--
CO_OP_TRANSLATOR_METADATA:
{
"original_hash": "b4612bbb9ace984f374fcc80e3e035ad",
"translation_date": "2025-08-25T21:41:56+00:00",
"source_file": "2-js-basics/2-functions-methods/README.md",
"language_code": "ne"
}
-->
# जाभास्क्रिप्ट आधारभूत: मेथड्स र फङ्सन्स
![JavaScript Basics - Functions](../../../../translated_images/webdev101-js-functions.be049c4726e94f8b7605c36330ac42eeb5cd8ed02bcdd60fdac778174d6cb865.ne.png)
> स्केच नोट [Tomomi Imura](https://twitter.com/girlie_mac) द्वारा
## प्रि-लेक्चर क्विज
[प्रि-लेक्चर क्विज](https://ff-quizzes.netlify.app/web/quiz/9)
जब हामी कोड लेख्ने कुरा सोच्छौं, हाम्रो कोड पढ्न सजिलो बनाउनु महत्त्वपूर्ण हुन्छ। यो अलि अचम्म लाग्न सक्छ, तर कोड लेखिएको भन्दा धेरै पटक पढिन्छ। डेभलपरको टूलबक्समा कोडलाई व्यवस्थित र सजिलो बनाउनको लागि एउटा मुख्य उपकरण भनेको **फङ्सन** हो।
[![Methods and Functions](https://img.youtube.com/vi/XgKsD6Zwvlc/0.jpg)](https://youtube.com/watch?v=XgKsD6Zwvlc "Methods and Functions")
> 🎥 माथिको तस्बिरमा क्लिक गरेर मेथड्स र फङ्सन्सको बारेमा भिडियो हेर्नुहोस्।
> तपाईं यो पाठ [Microsoft Learn](https://docs.microsoft.com/learn/modules/web-development-101-functions/?WT.mc_id=academic-77807-sagibbon) मा लिन सक्नुहुन्छ!
## फङ्सन्स
फङ्सन भनेको मुख्य रूपमा कोडको एउटा ब्लक हो, जसलाई हामी आवश्यक पर्दा चलाउन सक्छौं। यो त्यस्ता अवस्थामा उपयोगी हुन्छ, जहाँ एउटै काम बारम्बार गर्नुपर्छ। एउटै तर्कलाई धेरै ठाउँमा दोहोर्याउनुको सट्टा (जसले पछि अपडेट गर्न गाह्रो बनाउँछ), हामी यसलाई एउटै ठाउँमा राख्न सक्छौं र आवश्यक पर्दा चलाउन सक्छौं। तपाईंले फङ्सनलाई अर्को फङ्सनबाट पनि बोलाउन सक्नुहुन्छ!
फङ्सनलाई नाम दिन सक्ने क्षमता पनि उत्तिकै महत्त्वपूर्ण छ। यो सामान्य लाग्न सक्छ, तर नामले कोडको भागलाई छिटो बुझ्न मद्दत गर्छ। यसलाई बटनमा लेबल जस्तै सोच्न सकिन्छ। यदि मैले "Cancel timer" लेखिएको बटन क्लिक गरेँ भने, मलाई थाहा हुन्छ यसले घडी रोक्छ।
## फङ्सन बनाउने र बोलाउने
फङ्सनको सिंट्याक्स यस प्रकार देखिन्छ:
```javascript
function nameOfFunction() { // function definition
// function definition/body
}
```
यदि मैले अभिवादन देखाउने फङ्सन बनाउन चाहें भने, यो यसरी देखिन सक्छ:
```javascript
function displayGreeting() {
console.log('Hello, world!');
}
```
जब हामी हाम्रो फङ्सनलाई बोलाउन चाहन्छौं, हामी फङ्सनको नाम पछाडि `()` प्रयोग गर्छौं। हाम्रो फङ्सनलाई बोलाउनु अघि वा पछि परिभाषित गर्न सकिन्छ; जाभास्क्रिप्ट कम्पाइलरले यसलाई खोज्छ।
```javascript
// calling our function
displayGreeting();
```
> **NOTE:** एउटा विशेष प्रकारको फङ्सनलाई **मेथड** भनिन्छ, जुन तपाईंले पहिले नै प्रयोग गरिरहनुभएको छ! वास्तवमा, हामीले माथिको डेमोमा `console.log` प्रयोग गर्दा यो देख्यौं। मेथड र फङ्सनको फरक के हो भने, मेथड कुनै वस्तु (हाम्रो उदाहरणमा `console`) मा जोडिएको हुन्छ, जबकि फङ्सन स्वतन्त्र हुन्छ। धेरै डेभलपरहरूले यी दुई शब्दलाई परस्पर प्रयोग गर्छन्।
### फङ्सन बनाउँदा ध्यान दिनुपर्ने कुराहरू
फङ्सन बनाउँदा ध्यान दिनुपर्ने केही महत्त्वपूर्ण कुराहरू:
- सधैं वर्णनात्मक नामहरू प्रयोग गर्नुहोस् ताकि फङ्सनले के गर्छ भन्ने थाहा होस्।
- शब्दहरू जोड्न **camelCasing** प्रयोग गर्नुहोस्।
- फङ्सनलाई विशेष काममा केन्द्रित राख्नुहोस्।
## फङ्सनमा जानकारी पठाउने
फङ्सनलाई अझ उपयोगी बनाउन, तपाईंले प्रायः यसमा जानकारी पठाउन चाहनुहुन्छ। यदि हामीले माथिको `displayGreeting` उदाहरणलाई विचार गर्यौं भने, यसले केवल **Hello, world!** देखाउँछ। यो धेरै उपयोगी फङ्सन होइन। यदि हामी यसलाई अलि लचिलो बनाउन चाहन्छौं, जस्तै अभिवादन गर्ने व्यक्तिको नाम निर्दिष्ट गर्न दिनु, हामी **parameter** थप्न सक्छौं।
प्यारामिटरहरू परिभाषा भागमा कोष्ठकभित्र सूचीबद्ध गरिन्छ र कमाले छुट्याइन्छ:
```javascript
function name(param, param2, param3) {
}
```
हामी हाम्रो `displayGreeting` लाई नाम स्वीकार गर्न र देखाउन अद्यावधिक गर्न सक्छौं।
```javascript
function displayGreeting(name) {
const message = `Hello, ${name}!`;
console.log(message);
}
```
जब हामी हाम्रो फङ्सनलाई बोलाउन र प्यारामिटर पठाउन चाहन्छौं, हामी यसलाई कोष्ठकभित्र निर्दिष्ट गर्छौं।
```javascript
displayGreeting('Christopher');
// displays "Hello, Christopher!" when run
```
## डिफल्ट मानहरू
हामी हाम्रो फङ्सनलाई अझ लचिलो बनाउन थप प्यारामिटरहरू थप्न सक्छौं। तर यदि हामी चाहँदैनौं कि प्रत्येक मान अनिवार्य होस् भने के गर्ने? हाम्रो अभिवादन उदाहरणलाई ध्यानमा राख्दै, हामी नामलाई अनिवार्य राख्न सक्छौं (हामीलाई कसलाई अभिवादन गर्ने थाहा हुनुपर्छ), तर हामी चाहन्छौं कि अभिवादनलाई इच्छानुसार अनुकूलित गर्न सकियोस्। यदि कसैले यसलाई अनुकूलित गर्न चाहँदैन भने, हामी डिफल्ट मान प्रदान गर्छौं। प्यारामिटरलाई डिफल्ट मान प्रदान गर्न, हामी यसलाई भेरिएबलको मान सेट गरेजस्तै सेट गर्छौं - `parameterName = 'defaultValue'`। पूरा उदाहरण हेर्नुहोस्:
```javascript
function displayGreeting(name, salutation='Hello') {
console.log(`${salutation}, ${name}`);
}
```
जब हामी फङ्सनलाई बोलाउँछौं, हामी `salutation` को लागि मान सेट गर्ने निर्णय गर्न सक्छौं।
```javascript
displayGreeting('Christopher');
// displays "Hello, Christopher"
displayGreeting('Christopher', 'Hi');
// displays "Hi, Christopher"
```
## रिटर्न मानहरू
अहिलेसम्म हामीले बनाएको फङ्सनले सधैं [console](https://developer.mozilla.org/docs/Web/API/console) मा आउटपुट गर्छ। कहिलेकाहीं यो ठीक हुन्छ, विशेष गरी जब हामीले अन्य सेवाहरूलाई बोलाउने फङ्सनहरू बनाउँछौं। तर यदि मैले गणना गर्न र मानलाई अन्यत्र प्रयोग गर्नको लागि सहायक फङ्सन बनाउन चाहें भने के गर्ने?
हामी यो **रिटर्न मान** प्रयोग गरेर गर्न सक्छौं। रिटर्न मान फङ्सनबाट फर्काइन्छ, र यसलाई स्ट्रिङ वा नम्बर जस्तै स्थिर मानमा भण्डारण गर्न सकिन्छ।
यदि फङ्सनले केही फर्काउँछ भने `return` कीवर्ड प्रयोग गरिन्छ। `return` कीवर्डले फर्काइने मान वा सन्दर्भको अपेक्षा गर्छ:
```javascript
return myVariable;
```
हामी अभिवादन सन्देश बनाउन र मानलाई कलरलाई फर्काउन फङ्सन बनाउन सक्छौं।
```javascript
function createGreetingMessage(name) {
const message = `Hello, ${name}`;
return message;
}
```
जब हामी यो फङ्सनलाई बोलाउँछौं, हामी मानलाई भेरिएबलमा भण्डारण गर्छौं। यो स्थिर मान सेट गरेजस्तै हो (जस्तै `const name = 'Christopher'`)।
```javascript
const greetingMessage = createGreetingMessage('Christopher');
```
## फङ्सनलाई फङ्सनको प्यारामिटरको रूपमा प्रयोग गर्ने
जब तपाईं आफ्नो प्रोग्रामिङ करियरमा अगाडि बढ्नुहुन्छ, तपाईंले फङ्सनलाई फङ्सनको प्यारामिटरको रूपमा स्वीकार गर्ने फङ्सनहरू देख्नुहुनेछ। यो चतुर तरिका प्रायः त्यतिबेला प्रयोग गरिन्छ जब हामीलाई थाहा हुँदैन कि केही कहिले हुनेछ वा पूरा हुनेछ, तर हामीलाई थाहा छ कि प्रतिक्रिया स्वरूप कुनै अपरेसन गर्नुपर्छ।
उदाहरणको लागि, [setTimeout](https://developer.mozilla.org/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout) लाई विचार गर्नुहोस्, जसले टाइमर सुरु गर्छ र पूरा भएपछि कोड कार्यान्वयन गर्छ। हामीले यसलाई कुन कोड कार्यान्वयन गर्न चाहन्छौं भन्ने बताउनुपर्छ। यो काम फङ्सनको लागि उपयुक्त छ!
यदि तपाईं तलको कोड चलाउनुहुन्छ भने, ३ सेकेन्डपछि तपाईंले **3 seconds has elapsed** सन्देश देख्नुहुनेछ।
```javascript
function displayDone() {
console.log('3 seconds has elapsed');
}
// timer value is in milliseconds
setTimeout(displayDone, 3000);
```
### अनाम फङ्सनहरू
हामीले बनाएको कुरालाई फेरि हेरौं। हामी एउटा नाम भएको फङ्सन बनाउँदैछौं, जुन केवल एक पटक प्रयोग हुनेछ। हाम्रो एप्लिकेसन जति जटिल बन्छ, हामीले धेरै फङ्सनहरू बनाउँदैछौं, जुन केवल एक पटक बोलाइनेछ। यो आदर्श होइन। वास्तवमा, हामीले सधैं नाम दिन आवश्यक छैन!
जब हामी फङ्सनलाई प्यारामिटरको रूपमा पास गर्दैछौं, हामी यसलाई पहिले बनाउने प्रक्रियालाई बाइपास गर्न सक्छौं र यसको सट्टा प्यारामिटरको रूपमा बनाउँछौं। हामी `function` कीवर्ड प्रयोग गर्छौं, तर यसलाई प्यारामिटरको रूपमा बनाउँछौं।
हामीले माथिको कोडलाई अनाम फङ्सन प्रयोग गरेर पुनःलेखन गरौं:
```javascript
setTimeout(function() {
console.log('3 seconds has elapsed');
}, 3000);
```
यदि तपाईं हाम्रो नयाँ कोड चलाउनुहुन्छ भने, तपाईंले उस्तै नतिजा पाउनुहुनेछ। हामीले फङ्सन बनायौं, तर यसलाई नाम दिनुपरेन!
### फ्याट एरो फङ्सनहरू
धेरै प्रोग्रामिङ भाषाहरू (जाभास्क्रिप्ट सहित) मा सामान्य शर्टकट भनेको **एरो** वा **फ्याट एरो** फङ्सन प्रयोग गर्ने क्षमता हो। यसले `=>` भन्ने विशेष संकेतक प्रयोग गर्छ, जुन एरो जस्तो देखिन्छ - त्यसैले नाम! `=>` प्रयोग गरेर, हामी `function` कीवर्डलाई स्किप गर्न सक्छौं।
हामीले हाम्रो कोडलाई फ्याट एरो फङ्सन प्रयोग गरेर फेरि लेखौं:
```javascript
setTimeout(() => {
console.log('3 seconds has elapsed');
}, 3000);
```
### प्रत्येक रणनीति कहिले प्रयोग गर्ने
अब तपाईंले फङ्सनलाई प्यारामिटरको रूपमा पास गर्न तीन तरिकाहरू देख्नुभयो र सोच्न सक्नुहुन्छ कि कुन बेला कुन प्रयोग गर्ने। यदि तपाईंलाई थाहा छ कि तपाईंले फङ्सनलाई एकभन्दा बढी पटक प्रयोग गर्नुहुनेछ भने, यसलाई सामान्य रूपमा बनाउनुहोस्। यदि तपाईंले यसलाई केवल एक स्थानको लागि प्रयोग गर्नुहुनेछ भने, सामान्यतया अनाम फङ्सन प्रयोग गर्नु राम्रो हुन्छ। फ्याट एरो फङ्सन वा परम्परागत `function` सिंट्याक्स प्रयोग गर्ने निर्णय तपाईंको हो, तर तपाईंले देख्नुहुनेछ कि अधिकांश आधुनिक डेभलपरहरूले `=>` लाई प्राथमिकता दिन्छन्।
---
## 🚀 चुनौती
के तपाईं एक वाक्यमा फङ्सन र मेथडको बीचको फरक स्पष्ट गर्न सक्नुहुन्छ? प्रयास गर्नुहोस्!
## पोस्ट-लेक्चर क्विज
[पोस्ट-लेक्चर क्विज](https://ff-quizzes.netlify.app/web/quiz/10)
## समीक्षा र आत्म-अध्ययन
[एरो फङ्सनहरूको बारेमा](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Functions/Arrow_functions) थप पढ्न लायक छ, किनभने यी कोड बेसहरूमा बढ्दो रूपमा प्रयोग गरिन्छ। एउटा फङ्सन लेख्ने अभ्यास गर्नुहोस्, र त्यसपछि यसलाई यो सिंट्याक्स प्रयोग गरेर पुनःलेखन गर्नुहोस्।
## असाइनमेन्ट
[फन विथ फङ्सन्स](assignment.md)
**अस्वीकरण**:
यो दस्तावेज़ AI अनुवाद सेवा [Co-op Translator](https://github.com/Azure/co-op-translator) प्रयोग गरेर अनुवाद गरिएको छ। हामी शुद्धताको लागि प्रयास गर्छौं, तर कृपया ध्यान दिनुहोस् कि स्वचालित अनुवादमा त्रुटिहरू वा अशुद्धताहरू हुन सक्छ। यसको मूल भाषा मा रहेको मूल दस्तावेज़लाई आधिकारिक स्रोत मानिनुपर्छ। महत्वपूर्ण जानकारीको लागि, व्यावसायिक मानव अनुवाद सिफारिस गरिन्छ। यस अनुवादको प्रयोगबाट उत्पन्न हुने कुनै पनि गलतफहमी वा गलत व्याख्याको लागि हामी जिम्मेवार हुने छैनौं।