ईएस 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