Calling map() on an instance text of ConsoleText class that extends Array results in a ConsoleText(text.length) call (constructor input: 2 in the last line).
How to fix it so that text.map() calls Array constructor instead? Or it is a feature of inheritance?
EDIT: found an answer here
'use strict'
let initializingText = true;
class ConsoleText extends Array {
constructor(strings) {
console.log('constructor input:', strings);
if (initializingText) {
super(...strings);
} else {
super('item1', 'item2', 'item3', 'item4', 'item5');
}
}
}
let text = new ConsoleText(['a', 'b']); // constructor input: (2) ['a', 'b']
console.log('text:', text); // text: ConsoleText(2) ['a', 'b']
initializingText = false; // switch to escape error destructuring a number
console.log(text.map(() => 'q')); // constructor input: 2
// ConsoleText(5) ['q', 'q', 'item3', 'item4', 'item5']
Array.constructor accepts two different types of arguments:
new Array(element0, element1, /* … ,*/ elementN) - list of elements to create new arraynew Array(arrayLength) - array length, it will create an empty array then.So when you call Array.map, it will create a new array with the same instance class, pass array length into constructor and then will use Array.push to update that array. That is the reason why map logs array length in your case.
Furthermore, I do not recommend extending default data structure cause it can be really confusing. Maybe in your case you can just create a simple function, that returns generated array?
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With