Я хотел бы спросить, что я здесь делаю не так
Моя цель
Я хочу создавать экземпляры из конструктора класса. Первым будет более общий класс под названием Person, а затем другой, который унаследует свойства этого класса.
У меня вопрос
Когда все классы установлены и объявлен первый экземпляр, который указывает на конструктор Person, как можно передать key: values
предыдущего экземпляра следующему экземпляру, поскольку я не хочу повторять себя с теми же аргументами.
Я в настоящее время распространяет предыдущие параметры экземпляра, но, очевидно, я делаю что-то не так.
class Person {
constructor (name,yearOfBirth,job) {
this.name = name;
this.yearOfBirth = yearOfBirth;
this.job = job;
}
getAge() {
return new Date().getFullYear() - this.yearOfBirth
}
greet(){
return `${this.name} is a ${this.getAge()} years old ${this.job}`
}
}
class footballPlayer extends Person {
constructor(name,yearOfBirth, job, team, cups) {
super(name, yearOfBirth, job)
this.team = team;
this.cups = cups;
}
cupsWon() {
console.info(`${this.name} who was bord on ${this.year} and works as a ${this.job} won ${this.cups} with ${this.team}`);
}
}
const vagg = new Person('vaggelis', 1990, 'Developer');
const vaggA= new footballPlayer( {...vagg} , 'real madrid', 4)
console.info(vagg.greet());
console.info(vaggA.cupsWon());
Спасибо!
Если я правильно понимаю, что вы хотите сделать, вам нужно передать только значения параметров, описывающих Person
, в footballPlayer
(примечание: имена классов по соглашению должны быть в верхнем регистре).
var vaggA = new footballPlayer( ...Object.values(vagg) , 'real madrid', 4);
Редактировать: если вы опасаетесь другого порядка с Object.values
(который является реальная угроза), вы можете создать функцию получения в классе Person
, которая будет возвращать точный список параметров в том порядке, в котором они должны быть переданы конструктору:
class Person {
// ...
describe() {
return [this.name, this.yearOfBirth, this.job];
}
}
const vaggA = new footballPlayer( ...vagg.describe() , 'real madrid', 4);
Это не так в отношении ключей String
в 2018 году. Это можно обсудить, но отрицать ИМО нет необходимости.
К сожалению, ответ, который вы указали, просто неверен. См. Тот, который я привел цитатами из спецификации
Ваша ссылка говорит то же самое о строковых ключах: «Другие строковые ключи (если применимо) в порядке создания свойств».
Да, но это свойство гарантируется только для Object.getOwnPropertyNames
и т. д., нет для Object.keys
, Object.values
и Object.entries
.
Кстати, даже если бы они были в порядке создания свойств, этот подход слишком хрупкий, поскольку он ломается при изменении реализации конструктора.
Я отредактировал свой ответ, чтобы учесть ваши утверждения. Спасибо, что узнал об этом.
Вы не можете распределить объект по аргументам список. Вместо этого вы должны создать конструктор, который принимает объект.