ईएस 6 - इटरेटर

इटरेटर का परिचय

Iterator एक वस्तु है जो हमें एक समय में एक वस्तुओं के संग्रह तक पहुंचने की अनुमति देता है।

निम्नलिखित अंतर्निहित प्रकार डिफ़ॉल्ट रूप से चलने योग्य हैं -

  • String
  • Array
  • Map
  • Set

किसी वस्तु पर विचार किया जाता है iterable, यदि ऑब्जेक्ट एक फ़ंक्शन को लागू करता है जिसकी कुंजी है [Symbol.iterator]और एक पुनरावृत्ति देता है। एक के लिए ... पाश का उपयोग एक संग्रह को पुनरावृत्त करने के लिए किया जा सकता है।

उदाहरण

निम्नलिखित उदाहरण एक सरणी, निशान की घोषणा करता है, और इसके माध्यम से इसके माध्यम से पुनरावृत्त करता है for..of पाश।

<script>
   let marks = [10,20,30]
   //check iterable using for..of
   for(let m of marks){
      console.log(m);
   }
</script>

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

10
20
30

उदाहरण

निम्न उदाहरण एक सरणी घोषित करता है, निशान और एक पुनरावृत्त वस्तु को पुनः प्राप्त करता है। [Symbol.iterator]()एक पुनरावृत्त वस्तु को पुनः प्राप्त करने के लिए इस्तेमाल किया जा सकता है। पुनरावृत्त की अगली () विधि के साथ एक वस्तु देता है'value' तथा 'done'गुण । 'किया' बूलियन है और संग्रह में सभी वस्तुओं को पढ़ने के बाद सच हो जाता है।

<script>
   let marks = [10,20,30]
   let iter = marks[Symbol.iterator]();
   console.log(iter.next())
   console.log(iter.next())
   console.log(iter.next())
   console.log(iter.next())
</script>

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

{value: 10, done: false}
{value: 20, done: false}
{value: 30, done: false}
{value: undefined, done: true}

कस्टम Iterable

जावास्क्रिप्ट में कुछ प्रकार चलने योग्य हैं (जैसे एरे, मैप आदि) जबकि अन्य नहीं हैं (ईजी क्लास)। जावास्क्रिप्ट प्रकार जो डिफ़ॉल्ट रूप से चलने योग्य नहीं हैं, इसे पुनरावृत्त प्रोटोकॉल का उपयोग करके पुनरावृत्त किया जा सकता है।

निम्नलिखित उदाहरण नाम की एक कक्षा को परिभाषित करता है CustomerListजो एक सरणी के रूप में कई ग्राहक वस्तुओं को संग्रहीत करता है। प्रत्येक ग्राहक ऑब्जेक्ट में पहले नाम और अंतिम नाम गुण होते हैं।

इस वर्ग को चलने योग्य बनाने के लिए, क्लास को लागू करना होगा [Symbol.iterator]()समारोह। यह फ़ंक्शन एक पुनरावृत्त वस्तु देता है। पुनरावृत्त वस्तु का एक कार्य होता हैnext जो एक वस्तु देता है {value:'customer',done:true/false}

<script>
   //user defined iterable
   class CustomerList {
      constructor(customers){
         //adding customer objects to an array
         this.customers = [].concat(customers)
      }
      //implement iterator function
      [Symbol.iterator](){
         let count=0;
         let customers = this.customers
         return {
            next:function(){
            //retrieving a customer object from the array
               let customerVal = customers[count];
               count+=1;
               if(count<=customers.length){
                  return {
                     value:customerVal,
                     done:false
                  }
               }
               //return true if all customer objects are iterated
               return {done:true}
            }
         }
      }
   }
   //create customer objects
   let c1={
      firstName:'Sachin',
      lastName:'Tendulkar'
   }
   let c2={
      firstName:'Rahul',
      lastName:'Dravid'
   }
   //define a customer array and initialize it let customers=[c1,c2]
   //pass customers to the class' constructor
   let customersObj = new CustomerList(customers);
   //iterating using for..of
   for(let c of customersObj){
      console.log(c)
   }
   //iterating using the next() method
   let iter = customersObj[Symbol.iterator]();
   console.log(iter.next())
   console.log(iter.next())
   console.log(iter.next())
</script>

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

{firstName: "Sachin", lastName: "Tendulkar"}
{firstName: "Rahul", lastName: "Dravid"}
{
   done: false
   value: {
      firstName: "Sachin",
      lastName: "Tendulkar"
   }
}
{
   done: false
   value: {
      firstName: "Rahul",
      lastName: "Dravid"
   }
}
{done: true}

जनक

ईएस 6 से पहले, जावास्क्रिप्ट में फंक्शंस एक रन-टू पूरा मॉडल का पालन करते थे। ईएस 6 जनरेटर के रूप में जाने वाले कार्यों का परिचय देता है जो मध्य मार्ग को रोक सकता है और फिर जहां रुका है वहां से जारी रखता है।

एक जनरेटर एक तारांकन * वर्ण के साथ फ़ंक्शन नाम को उपसर्ग करता है और इसमें एक या अधिक होते हैं yieldबयान। yield कीवर्ड एक पुनरावृत्त वस्तु देता है।

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

function * generator_name() {
   yield value1
   ...
   yield valueN
}

उदाहरण

उदाहरण एक जनरेटर फ़ंक्शन को परिभाषित करता है getMarksतीन उपज बयानों के साथ। सामान्य कार्यों के विपरीत,generator function getMarks(), जब आह्वान किया जाता है, तो फ़ंक्शन निष्पादित नहीं करता है, लेकिन एक पुनरावृत्ति ऑब्जेक्ट देता है जो आपको जनरेटर फ़ंक्शन के अंदर कोड निष्पादित करने में मदद करता है।

करने के लिए पहली कॉल पर markIter.next()शुरुआत में परिचालन चलेगा और उपज विवरण जनरेटर के निष्पादन को रोक देगा। इसके बाद कॉल करता हैmarkIter.next() अगले तक जनरेटर फ़ंक्शन को फिर से शुरू करेगा yield अभिव्यक्ति।

<script>
   //define generator function
   function * getMarks(){
      console.log("Step 1")
      yield 10
      console.log("Step 2")
      yield 20
      console.log("Step 3")
      yield 30
      console.log("End of function")
   }
   //return an iterator object
      let markIter = getMarks()
   //invoke statements until first yield
      console.log(markIter.next())
   //resume execution after the last yield until second yield expression
      console.log(markIter.next())
   //resume execution after last yield until third yield expression
      console.log(markIter.next())
      console.log(markIter.next()) // iteration is completed;no value is returned
</script>

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

Step 1
{value: 10, done: false}
Step 2
{value: 20, done: false}
Step 3
{value: 30, done: false}
End of function
{value: undefined, done: true}

उदाहरण

निम्न उदाहरण के माध्यम से भी संख्याओं का एक अनंत क्रम बनाता है

* evenNumberGenerator जनरेटर फ़ंक्शन।

हम उपयोग करके सभी सम संख्याओं के माध्यम से पुनरावृति कर सकते हैं next() या उपयोग कर रहा है for of जैसा कि नीचे दिखाया गया है

<script>
   function * evenNumberGenerator(){
      let num = 0;
      while(true){
         num+=2
         yield num
      }
   }
   // display first two elements
   let iter = evenNumberGenerator();
   console.log(iter.next())
   console.log(iter.next())
   //using for of to iterate till 12
   for(let n of evenNumberGenerator()){
      if(n==12)break;
      console.log(n);
   }
</script>

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

{value: 2, done: false}
{value: 4, done: false}
2
4
6
8
10