I would like to set the options[Symbol.iterator]
property in order to iterate on the simple objects I create with the for...of
statement :
options = {
male: 'John',
female: 'Gina',
rel: 'Love'
};
for(let p of options){
console.log(`Property ${p}`);
};
But this code gives me the following error:
array.html:72 Uncaught TypeError: options[Symbol.iterator] is not a function
How I can set the right iterator function on a simple object as above?
Solved
// define the Iterator for the options object
options[Symbol.iterator] = function(){
// get the properties of the object
let properties = Object.keys(this);
let count = 0;
// set to true when the loop is done
isDone = false;
// define the next method, need for iterator
let next = () => {
// control on last property reach
if(count >= properties.length){
isDone = true;
}
return {done:isDone, value: this[properties[count++]]};
}
// return the next method used to iterate
return {next};
};
And I can use the for...of
statement on my object now iterable :
for(let property of options){
console.log(`Properties -> ${property}`);
}
for...of
loop, the collection would have to have a[Symbol.iterator]
property. Object literals do not have such a property, only arrays, Sets, maps etc do – TrisaMap
for that. – Overunder