Как распространить параметры предыдущего экземпляра конструктора класса на другой экземпляр

Я хотел бы спросить, что я здесь делаю не так

Моя цель

Я хочу создавать экземпляры из конструктора класса. Первым будет более общий класс под названием 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());

Спасибо!

Вы не можете распределить объект по аргументам список. Вместо этого вы должны создать конструктор, который принимает объект.

Bergi 22.11.2018 14:23
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
1
104
1

Ответы 1

Если я правильно понимаю, что вы хотите сделать, вам нужно передать только значения параметров, описывающих 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);
Object.valuesне гарантирует порядок, так что это может легко сломаться
Bergi 22.11.2018 14:20

Это не так в отношении ключей Stringв 2018 году. Это можно обсудить, но отрицать ИМО нет необходимости.

Zim 22.11.2018 14:39

К сожалению, ответ, который вы указали, просто неверен. См. Тот, который я привел цитатами из спецификации

Bergi 22.11.2018 15:02

Ваша ссылка говорит то же самое о строковых ключах: «Другие строковые ключи (если применимо) в порядке создания свойств».

Zim 22.11.2018 15:04

Да, но это свойство гарантируется только для Object.getOwnPropertyNames и т. д., нет для Object.keys, Object.values и Object.entries.

Bergi 22.11.2018 15:16

Кстати, даже если бы они были в порядке создания свойств, этот подход слишком хрупкий, поскольку он ломается при изменении реализации конструктора.

Bergi 22.11.2018 15:17

Я отредактировал свой ответ, чтобы учесть ваши утверждения. Спасибо, что узнал об этом.

Zim 22.11.2018 15:26

Другие вопросы по теме