# JavaScript Basics: पद्धती आणि फंक्शन्स ![JavaScript Basics - Functions](../../../../translated_images/webdev101-js-functions.be049c4726e94f8b7605c36330ac42eeb5cd8ed02bcdd60fdac778174d6cb865.mr.png) > स्केच नोट [Tomomi Imura](https://twitter.com/girlie_mac) यांनी तयार केले आहे ## प्री-लेक्चर क्विझ [प्री-लेक्चर क्विझ](https://ff-quizzes.netlify.app) कोड लिहिताना, आपला कोड वाचण्यायोग्य असावा याची खात्री करणे नेहमीच महत्त्वाचे असते. हे थोडेसे विरोधाभासी वाटू शकते, परंतु कोड लिहिल्यापेक्षा अनेक वेळा वाचला जातो. **फंक्शन** हे एक मुख्य साधन आहे जे विकसकाच्या टूलबॉक्समध्ये टिकाऊ कोड सुनिश्चित करण्यासाठी वापरले जाते. [![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 कंपाइलर ते शोधेल. ```javascript // calling our function displayGreeting(); ``` > **NOTE:** एक विशेष प्रकारचे फंक्शन आहे ज्याला **method** म्हणतात, जे तुम्ही आधीच वापरत आहात! खरं तर, आम्ही वरील डेमोमध्ये `console.log` वापरताना हे पाहिले. पद्धती आणि फंक्शनमधील फरक म्हणजे पद्धती एखाद्या ऑब्जेक्टशी जोडलेल्या असतात (`console` आमच्या उदाहरणात), तर फंक्शन स्वतंत्र असते. तुम्हाला अनेक विकसक हे शब्द परस्पर बदलून वापरताना ऐकू येतील. ### फंक्शनसाठी सर्वोत्तम पद्धती फंक्शन्स तयार करताना लक्षात ठेवण्यासाठी काही सर्वोत्तम पद्धती आहेत: - नेहमीप्रमाणे, वर्णनात्मक नावे वापरा जेणेकरून तुम्हाला फंक्शन काय करेल हे समजेल - शब्द एकत्र करण्यासाठी **camelCasing** वापरा - तुमचे फंक्शन्स विशिष्ट कार्यावर लक्ष केंद्रित करा ## फंक्शनला माहिती पास करणे फंक्शन अधिक पुनर्वापरयोग्य बनवण्यासाठी तुम्हाला त्यात माहिती पास करायची असते. जर आपण वरील `displayGreeting` उदाहरण विचारात घेतले, तर ते फक्त **Hello, world!** प्रदर्शित करेल. हे फारसे उपयुक्त फंक्शन नाही. जर आपण ते थोडे अधिक लवचिक बनवायचे असेल, जसे की अभिवादन करायच्या व्यक्तीचे नाव निर्दिष्ट करण्याची परवानगी देणे, तर आपण **parameter** जोडू शकतो. पॅरामीटर (कधीकधी **argument** असेही म्हणतात) म्हणजे फंक्शनला पाठवलेली अतिरिक्त माहिती. पॅरामीटर्स परिभाषा भागात कंसात सूचीबद्ध केले जातात आणि ते अल्पविरामाने वेगळे असतात: ```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 value** वापरून करू शकतो. रिटर्न मूल्य फंक्शनद्वारे परत केले जाते आणि आम्ही ते व्हेरिएबलमध्ये स्टोअर करू शकतो जसे की आम्ही स्ट्रिंग किंवा नंबरसारखे स्थिर मूल्य स्टोअर करू शकतो. जर फंक्शन काहीतरी परत करत असेल तर `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 सेकंदानंतर तुम्हाला संदेश दिसेल **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); ``` जर तुम्ही आमचा नवीन कोड चालवला तर तुम्हाला तेच परिणाम मिळतील. आम्ही एक फंक्शन तयार केले आहे, परंतु त्याला नाव देण्याची गरज नव्हती! ### फॅट अरो फंक्शन्स अनेक प्रोग्रामिंग भाषांमध्ये (JavaScript सह) सामान्य असलेली एक शॉर्टकट क्षमता म्हणजे **arrow** किंवा **fat arrow** फंक्शन वापरण्याची क्षमता. यात `=>` हा विशेष निर्देशक वापरला जातो, जो बाणासारखा दिसतो - म्हणून नाव! `=>` वापरून, आम्ही `function` कीवर्ड वगळू शकतो. आमचा कोड पुन्हा एकदा फॅट अरो फंक्शन वापरण्यासाठी लिहूया: ```javascript setTimeout(() => { console.log('3 seconds has elapsed'); }, 3000); ``` ### प्रत्येक रणनीती कधी वापरायची तुम्ही आता पाहिले आहे की आम्ही फंक्शनला पॅरामीटर म्हणून पास करण्याचे तीन मार्ग आहेत आणि तुम्हाला कदाचित आश्चर्य वाटेल की प्रत्येक कधी वापरायचा. जर तुम्हाला माहित असेल की तुम्ही फंक्शन एकापेक्षा जास्त वेळा वापरणार आहात, तर ते सामान्य पद्धतीने तयार करा. जर तुम्ही ते फक्त एका ठिकाणी वापरणार असाल, तर सामान्यतः अनामिक फंक्शन वापरणे चांगले असते. तुम्ही फॅट अरो फंक्शन वापरायचे की अधिक पारंपरिक `function` सिंटॅक्स वापरायचे हे तुमच्यावर अवलंबून आहे, परंतु तुम्हाला लक्षात येईल की बहुतेक आधुनिक विकसक `=>` ला प्राधान्य देतात. --- ## 🚀 आव्हान फंक्शन्स आणि पद्धतींमधील फरक एका वाक्यात स्पष्ट करू शकता का? प्रयत्न करा! ## पोस्ट-लेक्चर क्विझ [पोस्ट-लेक्चर क्विझ](https://ff-quizzes.netlify.app) ## पुनरावलोकन आणि स्व-अभ्यास [अरो फंक्शन्सबद्दल थोडे अधिक वाचणे](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Functions/Arrow_functions) फायदेशीर ठरू शकते, कारण ते कोड बेसमध्ये अधिकाधिक वापरले जात आहेत. फंक्शन लिहिण्याचा सराव करा आणि नंतर या सिंटॅक्ससह ते पुन्हा लिहा. ## असाइनमेंट [Fun with Functions](assignment.md) --- **अस्वीकरण**: हा दस्तऐवज AI भाषांतर सेवा [Co-op Translator](https://github.com/Azure/co-op-translator) वापरून भाषांतरित करण्यात आला आहे. आम्ही अचूकतेसाठी प्रयत्नशील असलो तरी कृपया लक्षात ठेवा की स्वयंचलित भाषांतरांमध्ये त्रुटी किंवा अचूकतेचा अभाव असू शकतो. मूळ भाषेतील दस्तऐवज हा अधिकृत स्रोत मानला जावा. महत्त्वाच्या माहितीसाठी व्यावसायिक मानवी भाषांतराची शिफारस केली जाते. या भाषांतराचा वापर करून निर्माण होणाऱ्या कोणत्याही गैरसमज किंवा चुकीच्या अर्थासाठी आम्ही जबाबदार राहणार नाही.