Придумал как сделать.
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<script>
let Person = function Pers(name, age, gender) { // Имя будет Pers
this.name = name;
this.age = age;
this.gender = gender;
};
Person.prototype.greet = function () {
console.log("My name is " + this.name);
}
let Person2 = Person;
Person2.prototype.goodbye = function () {
console.log("Goodbye, " + this.name);
}
let Son = function (name,age,gender,skils) { // Имя будет Son
// Родительский конструктор вызывается до дочернего конструктора,
// чтобы не было перезаписывания новых полей.
Person.call(this, name, age, gender);
this.skils = skils || [];
}
let Sunny = Son;
Sunny.prototype = Object.create(Person.prototype);
Sunny.prototype.constructor = Sunny; // Имя будет Son
let a = new Person("Петя", 25, "female");
console.log(a);
console.log(a.constructor.name);
let b = new Son(a.name,a.age,a.gender, ["рисует", "поет", "водит"]);
console.log(b);
console.log(b.name);
</script>
</body>
</html>
Просто засунул объект а созданный от Person в сына в качестве аргументов.
let b = new Son(a.name,a.age,a.gender, ["рисует", "поет", "водит"]);
Я просто хотел понять как наследовать потомку свойства и значения полученные конструктором родителя, добавляя в потомке еще свои свойства, расширяя класс родителя.