Sposoby rozszerzania obiektu Array w javascript
próbuję rozszerzyć obiekt Array w javascript za pomocą pewnych przyjaznych dla użytkownika metod, takich jak Array.Add () zamiast Array.push () itd ...
implementuję 3 sposoby, aby to zrobić. niestety trzeci sposób nie działa i chcę zapytać dlaczego? i jak to działa.
//------------- 1st way
Array.prototype.Add=function(element){
this.push(element);
};
var list1 = new Array();
list1.Add("Hello world");
alert(list1[0]);
//------------- 2nd way
function Array2 () {
//some other properties and methods
};
Array2.prototype = new Array;
Array2.prototype.Add = function(element){
this.push(element);
};
var list2 = new Array2;
list2.Add(123);
alert(list2[0]);
//------------- 3rd way
function Array3 () {
this.prototype = new Array;
this.Add = function(element){
this.push(element);
};
};
var list3 = new Array3;
list3.Add(456); //push is not a function
alert(list3[0]); // undefined
w trzeci sposób chcę rozszerzyć obiekt Array wewnętrznie klasę Array3. Jak to zrobić, aby nie uzyskać „push nie jest funkcją” i „niezdefiniowane”?
Tutaj dodaję czwarty sposób.
//------------- 4th way
function Array4 () {
//some other properties and methods
this.Add = function(element){
this.push(element);
};
};
Array4.prototype = new Array();
var list4 = new Array4();
list4.Add(789);
alert(list4[0]);
Tutaj znowu muszę użyć prototypu. Miałem nadzieję uniknąć używania dodatkowych linii poza konstruktorem klasy jako Array4.prototype. Chciałem mieć kompaktową klasę ze wszystkimi elementami w jednym miejscu. Ale myślę, że nie mogę tego zrobić inaczej.