ईएस 6 - कार्य

Functionsपठनीय, बनाए रखने योग्य और पुन: प्रयोज्य कोड के निर्माण खंड हैं। फ़ंक्शन कीवर्ड का उपयोग करके फ़ंक्शंस परिभाषित किए जाते हैं। मानक फ़ंक्शन को परिभाषित करने के लिए सिंटैक्स निम्नलिखित है।

function function_name() { 
   // function body 
}

फ़ंक्शन के निष्पादन को मजबूर करने के लिए, इसे कॉल करना होगा। इसे फंक्शन इनवोकेशन कहा जाता है। एक समारोह आह्वान करने के लिए वाक्य रचना निम्नलिखित है।

function_name()

उदाहरण: सरल कार्य परिभाषा

//define a  function 
function test() { 
   console.log("function called") 
} 
//call the function 
test()

उदाहरण एक फ़ंक्शन परीक्षण () को परिभाषित करता है। डेलिमिटर ({}) की एक जोड़ी फ़ंक्शन बॉडी को परिभाषित करती है। इसे भी कहा जाता हैfunction scope। इसके निष्पादन को मजबूर करने के लिए एक फ़ंक्शन को लागू किया जाना चाहिए।

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

function called

कार्यों का वर्गीकरण

कार्यों को वर्गीकृत किया जा सकता है Returning तथा Parameterized कार्य करता है।

लौटने के कार्य

नियंत्रण वापस कॉल करने वाले के साथ-साथ मूल्य भी वापस कर सकता है। ऐसे कार्यों को रिटर्निंग फ़ंक्शन कहा जाता है।

निम्न फ़ंक्शन के लिए सिंटैक्स है।

function function_name() { 
   //statements 
   return value; 
}
  • रिटर्न स्टेटमेंट को रिटर्न स्टेटमेंट के साथ समाप्त होना चाहिए।

  • एक फ़ंक्शन सबसे अधिक मूल्य पर वापस आ सकता है। दूसरे शब्दों में, प्रति फ़ंक्शन केवल एक रिटर्न स्टेटमेंट हो सकता है।

  • फ़ंक्शन में रिटर्न स्टेटमेंट अंतिम स्टेटमेंट होना चाहिए।

निम्नलिखित कोड स्निपेट एक रिटर्निंग फ़ंक्शन का एक उदाहरण है -

function retStr() { 
   return "hello world!!!" 
}  
var val = retStr() 
console.log(val)

उपरोक्त उदाहरण एक फ़ंक्शन को परिभाषित करता है जो स्ट्रिंग को लौटाता है "हैलो वर्ल्ड !!!" फोन करने वाले को। उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

hello world!!!

परिमेय कार्य

पैरामीटर फ़ंक्शन के मानों को पारित करने के लिए एक तंत्र है। पैरामीटर फ़ंक्शन के हस्ताक्षर का एक हिस्सा बनाते हैं। पैरामीटर मान को इसके मंगलाचरण के दौरान फ़ंक्शन में पास किया जाता है। जब तक स्पष्ट रूप से निर्दिष्ट नहीं किया जाता है, तब तक फ़ंक्शन के लिए दिए गए मानों की संख्या निर्धारित मापदंडों की संख्या से मेल खाना चाहिए।

निम्नलिखित एक पैरामीटर फ़ंक्शन को परिभाषित करने वाला सिंटैक्स है।

function func_name( param1,param2 ,…..paramN) {   
   ...... 
   ...... 
}

Example − Parameterized Function

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

function add( n1,n2) { 
   var sum = n1 + n2 
   console.log("The sum of the values entered "+sum) 
} 
add(12,13)

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

The sum of the values entered 25

डिफ़ॉल्ट फ़ंक्शन पैरामीटर

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

function add(a, b = 1) { 
   return a+b; 
} 
console.log(add(4))

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

5

यदि फ़ंक्शन स्पष्ट रूप से मान पास करता है, तो पैरामीटर्स का डिफ़ॉल्ट मान अधिलेखित हो जाएगा।

function add(a, b = 1) { 
   return a + b; 
} 
console.log(add(4,2))

उपरोक्त कोड पैरामीटर बी के मूल्य को स्पष्ट रूप से 2 पर सेट करता है, जिससे इसका डिफ़ॉल्ट मूल्य ओवरराइट हो जाता है। उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

6

बेहतर समझ के लिए, हम नीचे दिए गए उदाहरण पर विचार करें।

उदाहरण 1

निम्न उदाहरण एक फ़ंक्शन को दर्शाता है जो दो मापदंडों को लेता है और उनकी राशि लौटाता है। दूसरे पैरामीटर का डिफ़ॉल्ट मान होता है 10. इसका मतलब है, अगर कोई मान दूसरे पैरामीटर से पारित नहीं होता है, तो इसका मान 10 होगा।

<script>
   function addTwoNumbers(first,second = 10){
      console.log('first parameter is :',first)
      console.log('second parameter is :',second)
      return first+second;
   }

   console.log("case 1 sum:",addTwoNumbers(20)) // no value
   console.log("case 2 sum:",addTwoNumbers(2,3))
   console.log("case 3 sum:",addTwoNumbers())
   console.log("case 4 sum",addTwoNumbers(1,null))//null passed
   console.log("case 5 sum",addTwoNumbers(3,undefined))
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

first parameter is : 20
second parameter is : 10
case 1 sum: 30
first parameter is : 2
second parameter is : 3
case 2 sum: 5
first parameter is : undefined
second parameter is : 10
case 3 sum: NaN
first parameter is : 1
second parameter is : null
case 4 sum 1
first parameter is : 3
second parameter is : 10
case 5 sum 13

उदाहरण 2

<script>
   let DEFAULT_VAL = 30
      function addTwoNumbers(first,second = DEFAULT_VAL){
         console.log('first parameter is :',first)
         console.log('second parameter is :',second)
         return first+second;
      }
      console.log("case 1 sum",addTwoNumbers(1))
      console.log("case 2 sum",addTwoNumbers(3,undefined))
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

first parameter is : 1
second parameter is : 30
case 1 sum 31
first parameter is : 3
second parameter is : 30
case 2 sum 33

बाकी पैरामीटर

बाकी पैरामीटर जावा में चर तर्कों के समान हैं। बाकी पैरामीटर उन मानों की संख्या को सीमित नहीं करते हैं जिन्हें आप किसी फ़ंक्शन में पास कर सकते हैं। हालाँकि, दिए गए मान सभी एक ही प्रकार के होने चाहिए। दूसरे शब्दों में, बाकी पैरामीटर एक ही प्रकार के कई तर्कों के लिए प्लेसहोल्डर के रूप में कार्य करते हैं।

बाकी पैरामीटर घोषित करने के लिए, पैरामीटर नाम को तीन अवधियों के साथ उपसर्ग किया जाता है, जिसे प्रसार ऑपरेटर के रूप में जाना जाता है। निम्न उदाहरण उसी का चित्रण करता है।

function fun1(...params) { 
   console.log(params.length); 
}  
fun1();  
fun1(5); 
fun1(5, 6, 7);

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

0 
1 
3

Note - बाकी पैरामीटर किसी फ़ंक्शन की पैरामीटर सूची में अंतिम होना चाहिए।

अनाम क्रिया

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

चर को एक अनाम फ़ंक्शन सौंपा जा सकता है। ऐसी अभिव्यक्ति को ए कहा जाता हैfunction expression

अनाम फ़ंक्शन के लिए सिंटैक्स निम्नलिखित है।

var res = function( [arguments] ) { ... }

Example − Anonymous Function

var f = function(){ return "hello"} 
console.log(f())

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

hello

Example − Anonymous Parameterized Function

var func = function(x,y){ return x*y }; 
function product() { 
   var result; 
   result = func(10,20); 
   console.log("The product : "+result) 
} 
product()

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

The product : 200

समारोह निर्माता

फ़ंक्शन स्टेटमेंट एक नए फ़ंक्शन को परिभाषित करने का एकमात्र तरीका नहीं है; आप नए ऑपरेटर के साथ फ़ंक्शन () कंस्ट्रक्टर का उपयोग करके अपने फ़ंक्शन को गतिशील रूप से परिभाषित कर सकते हैं।

नए ऑपरेटर के साथ फ़ंक्शन () कंस्ट्रक्टर का उपयोग करके फ़ंक्शन बनाने के लिए सिंटैक्स निम्नलिखित है।

var variablename = new Function(Arg1, Arg2..., "Function Body");

फंक्शन () कंस्ट्रक्टर किसी भी संख्या में स्ट्रिंग तर्क की अपेक्षा करता है। अंतिम तर्क फ़ंक्शन का निकाय है - इसमें मनमाने ढंग से जावास्क्रिप्ट स्टेटमेंट हो सकते हैं, जो अर्धविराम द्वारा एक दूसरे से अलग होते हैं।

फ़ंक्शन () निर्माता किसी भी तर्क को पारित नहीं करता है जो उस फ़ंक्शन के लिए एक नाम निर्दिष्ट करता है जो इसे बनाता है।

Example − Function Constructor

var func = new Function("x", "y", "return x*y;"); 
function product() { 
   var result; 
   result = func(10,20); 
   console.log("The product : "+result)
} 
product()

उपरोक्त उदाहरण में, फ़ंक्शन () निर्माता का उपयोग एक अनाम फ़ंक्शन को परिभाषित करने के लिए किया जाता है। फ़ंक्शन दो मापदंडों को स्वीकार करता है और उनके उत्पाद को लौटाता है।

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

The product : 200

पुनरावर्तन और जावास्क्रिप्ट कार्य

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

Example − Recursion

function factorial(num) { 
   if(num <= 0) { 
      return 1; 
   } else { 
      return (num * factorial(num-1)  ) 
   } 
} 
console.log(factorial(6))

उपरोक्त उदाहरण में फ़ंक्शन स्वयं कॉल करता है। उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

720

Example − Anonymous Recursive Function

(function() { 
   var msg = "Hello World" 
   console.log(msg)
})()

फ़ंक्शन स्वयं को कोष्ठक () की एक जोड़ी का उपयोग करके कहता है। उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

Hello World

लंबोदर कार्य

लैम्ब्डा प्रोग्रामिंग में अनाम कार्यों को संदर्भित करता है। अनाम कार्यों का प्रतिनिधित्व करने के लिए लैम्ब्डा फ़ंक्शन एक संक्षिप्त तंत्र हैं। इन कार्यों को भी कहा जाता हैArrow functions

लैम्ब्डा फंक्शन - एनाटॉमी

लाम्बा समारोह के 3 भाग हैं -

  • Parameters - एक फ़ंक्शन में वैकल्पिक रूप से पैरामीटर हो सकते हैं।

  • fat arrow notation/lambda notation (=>): इसे ऑपरेटर के रूप में भी जाना जाता है।

  • Statements - फ़ंक्शन के अनुदेश सेट का प्रतिनिधित्व करता है।

Tip - सम्मेलन द्वारा, एक कॉम्पैक्ट और सटीक फ़ंक्शन घोषणा के लिए एकल अक्षर पैरामीटर के उपयोग को प्रोत्साहित किया जाता है।

लैम्ब्डा एक्सप्रेशन

यह एक अनाम फ़ंक्शन एक्सप्रेशन है जो कोड की एकल पंक्ति को इंगित करता है। निम्नलिखित के लिए सिंटैक्स है।

([param1, parma2,…param n] )=>statement;

Example − Lambda Expression

var foo = (x)=>10+x 
console.log(foo(10))

उदाहरण एक लंबोदर अभिव्यक्ति फ़ंक्शन घोषित करता है। फ़ंक्शन 10 का योग लौटाता है और तर्क पास हो जाता है।

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

20

लाम्बा स्टेटमेंट

यह एक अनाम फ़ंक्शन घोषणा है जो कोड के एक ब्लॉक को इंगित करता है। इस सिंटैक्स का उपयोग तब किया जाता है जब फ़ंक्शन बॉडी कई लाइनों को फैलाता है। निम्नलिखित उसी का वाक्य विन्यास है।

( [param1, parma2,…param n] )=> {       
   //code block 
}

Example − Lambda Statement

var msg = ()=> { 
   console.log("function invoked") 
} 
msg()

फ़ंक्शन का संदर्भ लौटाया गया है और चर संदेश में संग्रहीत किया गया है। उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

function  invoked

संश्लिष्ट रूपांतर

एकल पैरामीटर के लिए वैकल्पिक कोष्ठक।

var msg = x=> { 
   console.log(x) 
} 
msg(10)

एक बयान के लिए वैकल्पिक ब्रेसिज़। कोई पैरामीटर के लिए खाली कोष्ठक।

var disp = ()=>console.log("Hello World") 
disp();

समारोह अभिव्यक्ति और समारोह घोषणा

फंक्शन एक्सप्रेशन और फंक्शन डिक्लेरेशन पर्यायवाची नहीं हैं। एक फ़ंक्शन अभिव्यक्ति के विपरीत, एक फ़ंक्शन घोषणा फ़ंक्शन नाम से बाध्य है।

दोनों के बीच मूलभूत अंतर यह है कि, कार्य घोषणाएं उनके निष्पादन से पहले पार्स की जाती हैं। दूसरी ओर, फ़ंक्शन अभिव्यक्तियों को केवल तब ही पार्स किया जाता है जब स्क्रिप्ट इंजन इसे एक निष्पादन के दौरान सामना करता है।

जब जावास्क्रिप्ट पार्सर मुख्य कोड प्रवाह में एक फ़ंक्शन देखता है, तो यह फ़ंक्शन घोषणा को मानता है। जब कोई फ़ंक्शन किसी कथन के भाग के रूप में आता है, तो यह एक फ़ंक्शन एक्सप्रेशन है।

फहराने की क्रिया

चरों की तरह, फ़ंक्शंस भी फहराए जा सकते हैं। चरों के विपरीत, फंक्शन की घोषणाएं जब फहराई जाती हैं, तो फ़ंक्शन के नाम को फहराने के बजाय फ़ंक्शन की परिभाषा को बढ़ाता है।

निम्नलिखित कोड स्निपेट, जावास्क्रिप्ट में फहराए जाने वाले फ़ंक्शन को दिखाता है।

hoist_function();  
function hoist_function() { 
   console.log("foo"); 
}

उपरोक्त कोड के सफल निष्पादन पर निम्नलिखित आउटपुट प्रदर्शित होते हैं।

foo

हालाँकि, फ़ंक्शन अभिव्यक्तियों को फहराया नहीं जा सकता। निम्न कोड स्निपेट समान दिखाता है।

hoist_function(); // TypeError: hoist_function() is not a function  
var hoist_function() = function() { 
   console.log("bar"); 
};

तुरंत फंक्शन अभिव्यक्ति

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

उदाहरण 1: IIFE

var main = function() { 
   var loop = function() { 
      for(var x = 0;x<5;x++) {
         console.log(x); 
      } 
   }(); 
   console.log("x can not be accessed outside the block scope x value is :"+x); 
} 
main();

उदाहरण 2: IIFE

var main = function() { 
   (function() { 
      for(var x = 0;x<5;x++) { 
         console.log(x); 
      } 
   })(); 
   console.log("x can not be accessed outside the block scope x value is :"+x); 
} 
main();

दोनों उदाहरण निम्नलिखित आउटपुट प्रस्तुत करेंगे।

0 
1 
2 
3 
4 
Uncaught ReferenceError: x is not define

जेनरेटर के कार्य

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

  • फ़ंक्शन किसी भी बिंदु पर कॉलर को वापस नियंत्रित कर सकता है।

  • जब आप एक जनरेटर को बुलाते हैं, तो यह तुरंत नहीं चलता है। इसके बजाय, आप एक पुनरावृत्तिकर्ता प्राप्त करते हैं। फ़ंक्शन चलता है जैसे ही आप इट्रेटर की अगली विधि कहते हैं।

जेनरेटर को तारांकन चिह्न के साथ फ़ंक्शन कीवर्ड को दबाकर निरूपित किया जाता है; अन्यथा, उनका सिंटैक्स नियमित कार्यों के समान है।

निम्न उदाहरण उसी का चित्रण करता है।

"use strict" 
function* rainbow() { 
   // the asterisk marks this as a generator 
   yield 'red'; 
   yield 'orange'; 
   yield 'yellow'; 
   yield 'green'; 
   yield 'blue'; 
   yield 'indigo'; 
   yield 'violet'; 
} 
for(let color of rainbow()) { 
   console.log(color); 
}

जनरेटर कॉल करने वाले और बुलाया फ़ंक्शन के बीच दो-तरफ़ा संचार सक्षम करते हैं। यह का उपयोग करके पूरा किया हैyield कीवर्ड।

निम्नलिखित उदाहरण पर विचार करें -

function* ask() { 
   const name = yield "What is your name?"; 
   const sport = yield "What is your favorite sport?"; 
   return `${name}'s favorite sport is ${sport}`; 
}  
const it = ask(); 
console.log(it.next()); 
console.log(it.next('Ethan'));  
console.log(it.next('Cricket'));

जनरेटर फ़ंक्शन की अनुक्रम निम्नानुसार है -

  • बताए गए तरीके से शुरू किया गया जनरेटर; पुनरावृतिकर्ता लौटा दिया गया है

  • It.next () पैदावार "आपका नाम क्या है"। जनरेटर को रोक दिया जाता है। यह उपज कीवर्ड द्वारा किया जाता है।

  • कॉल इट.नेक्स्ट ("एथन"), एथन को वैरिएबल नाम के लिए मान देता है और "आपका स्पोर्ट क्या है?" फिर से जनरेटर को रोक दिया जाता है।

  • कॉल it.next ("क्रिकेट") चर खेल के लिए मूल्य क्रिकेट प्रदान करता है और बाद के विवरण को निष्पादित करता है।

इसलिए, उपरोक्त कोड का उत्पादन होगा -

{ 
   value: 'What is your name?', done: false 
} 
{ 
   value: 'What is your favorite sport?', done: false 
} 
{ 
   value: 'Ethan\'s favorite sport is Cricket', done: true 
}

Note - तीर फ़ंक्शन का उपयोग करके जनरेटर कार्यों का प्रतिनिधित्व नहीं किया जा सकता है।

तीर कार्य

ES में पेश किए गए एरो फ़ंक्शंस जावास्क्रिप्ट में फ़ंक्शन को संक्षिप्त तरीके से लिखने में मदद करते हैं। आइए अब उसी के बारे में विस्तार से जानें।

ES5 और बेनामी फ़ंक्शन

जावास्क्रिप्ट का भारी उपयोग करता है anonymous functions। एक अनाम फ़ंक्शन एक फ़ंक्शन होता है जिसमें कोई नाम जुड़ा नहीं होता है। बेनामी कार्यों के दौरान उपयोग किया जाता हैfunction callback। निम्न उदाहरण ईएस 5 में एक अनाम फ़ंक्शन के उपयोग को दिखाता है -

<script>
   setTimeout(function(){
      console.log('Learning at TutorialsPoint is fun!!')
   },1000)
</script>

उपर्युक्त उदाहरण पूर्वनिर्धारित के पैरामीटर के रूप में एक अनाम फ़ंक्शन पास करता है setTimeout() function। सेटटाइमआउट () फ़ंक्शन 1 सेकंड के बाद अनाम फ़ंक्शन को कॉलबैक करेगा।

निम्नलिखित उत्पादन 1 सेकंड के बाद दिखाया गया है -

Learning at TutorialsPoint is fun!!

एरो फंक्शन सिंटेक्स

ES6 की अवधारणा का परिचय देता है arrow function के उपयोग को आसान बनाने के लिए anonymous function। एक एरो फंक्शन के 3 भाग हैं जो इस प्रकार हैं -

  • Parameters - एक तीर फ़ंक्शन वैकल्पिक रूप से पैरामीटर हो सकता है

  • The fat arrow notation (=>) - इसे ऑपरेटर के रूप में भी जाना जाता है

  • Statements - फ़ंक्शन के अनुदेश सेट का प्रतिनिधित्व करता है

Tip - सम्मेलन द्वारा, एक कॉम्पैक्ट और सटीक तीर फ़ंक्शन घोषणा के लिए एक एकल अक्षर पैरामीटर के उपयोग को प्रोत्साहित किया जाता है।

वाक्य - विन्यास

//Arrow function that points to a single line of code
()=>some_expression

या

//Arrow function that points to a block of code
()=> { //some statements }`

या

//Arrow function with parameters
(param1,param2)=>{//some statement}

उदाहरण: ES6 में एरो फंक्शन

निम्न उदाहरण दो फ़ंक्शन अभिव्यक्तियों को परिभाषित करता है add तथा isEven एरो फंक्शन का उपयोग करना

<script>
   const add = (n1,n2) => n1+n2
   console.log(add(10,20))

   const isEven = (n1) => {
      if(n1%2 == 0)
         return true;
      else
         return false;
   }
   console.log(isEven(10))
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

30
true

Array.prototyp.map () और एरो फंक्शन

निम्नलिखित उदाहरण में, एक तीर फ़ंक्शन को पैरामीटर के रूप में पास किया जाता है Array.prototype.map() function.नक्शा () फ़ंक्शन सरणी में प्रत्येक तत्व के लिए तीर फ़ंक्शन को निष्पादित करता है। इस मामले में तीर फ़ंक्शन, सरणी और उसके सूचकांक में प्रत्येक तत्व को प्रदर्शित करता है।

<script>
   const names = ['TutorialsPoint','Mohtashim','Bhargavi','Raja']
   names.map((element,index)=> {
      console.log('inside arrow function')
      console.log('index is '+index+' element value is :'+element)
   })
</script>

उपरोक्त कोड का आउटपुट नीचे दिया गया है -

inside arrow function
index is 0 element value is :TutorialsPoint
inside arrow function
index is 1 element value is :Mohtashim
inside arrow function
index is 2 element value is :Bhargavi
inside arrow function
index is 3 element value is :Raja

उदाहरण: window.setTimeout () और एरो फंक्शन

निम्न उदाहरण पूर्वनिर्धारित के पैरामीटर के रूप में एक तीर फ़ंक्शन पास करता है setTimeout() functionsetTimeout() फ़ंक्शन 1 सेकंड के बाद एरो फ़ंक्शन को कॉलबैक करेगा।

<script>
   setTimeout(()=>{
      console.log('Learning at TutorialsPoint is fun!!')
   },1000)
</script>

निम्नलिखित उत्पादन 1 सेकंड के बाद दिखाया गया है -

Learning at TutorialsPoint is fun!!

एरो फ़ंक्शन और "यह"

अगर हम उपयोग करते हैं तो एक एरो फंक्शन के अंदर this pointer, यह घेरने वाले शाब्दिक दायरे की ओर इशारा करेगा। इसका मतलब है कि तीर फ़ंक्शंस एक नया नहीं बनाते हैंthis pointerउदाहरण के लिए जब भी इसे लागू किया जाता है। एरो फ़ंक्शंस इसके संलग्न दायरे का उपयोग करता है। इसे समझने के लिए, हम एक उदाहरण देखते हैं।

<script>
   //constructor function
   function Student(rollno,firstName,lastName) {
      this.rollno = rollno;
      this.firstName = firstName;
      this.lastName = lastName;
      this.fullNameUsingAnonymous = function(){
         setTimeout(function(){
            //creates a new instance of this ,hides outer scope of this
            console.log(this.firstName+ " "+this.lastName)
         },2000)
      }
      this.fullNameUsingArrow = function(){
         setTimeout(()=>{
            //uses this instance of outer scope
            console.log(this.firstName+ " "+this.lastName)
         },3000)
      }
   }
   const s1 = new Student(101,'Mohammad','Mohtashim')
   s1.fullNameUsingAnonymous();
   s1.fullNameUsingArrow();
</script>

जब एक अनाम फ़ंक्शन का उपयोग किया जाता है setTimeout()2000 मिलीसेकंड के बाद फ़ंक्शन को लागू किया जाता है। का एक नया उदाहरण“this”बनाया गया है और यह छात्र फ़ंक्शन के उदाहरण को छाया देता है। तो, का मूल्यthis.firstName तथा this.lastName होगा undefined। फ़ंक्शन लेक्सिकल स्कोप या वर्तमान निष्पादन के संदर्भ का उपयोग नहीं करता है। A का उपयोग करके इस समस्या को हल किया जा सकता हैarrow function

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

undefined undefined
Mohammad Mohtashim