Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Array map calls the constructor of a class that extends Array instead of calling Array constructor

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']
like image 367
Pootis Spencer Avatar asked Oct 26 '25 08:10

Pootis Spencer


1 Answers

Array.constructor accepts two different types of arguments:

  • new Array(element0, element1, /* … ,*/ elementN) - list of elements to create new array
  • new 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?

like image 142
KiraLT Avatar answered Oct 28 '25 22:10

KiraLT



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!