Изучаю прототипы и добавляю к ним методы [call
, bind
, apply
] и столкнулся с такой фичей.
Не понимаю откуда берется undefined
.
Растолкуйте пожалуйста.
function greet() {
console.log(`Hello! My name is ${this.name}, I'm ${this.job}`);
}
function Person(name, job) {
this.name = name;
this.job = job;
}
Person.prototype.greet = function() {
return greet.call(this);
}
const person = new Person('Richard', 'developer');
console.log(person.greet());
У вас функция greet ничего не возвращает потому что.
Добавить return и получите, что и ожидали
function greet() {
return(`Hello! My name is ${this.name}, I'm ${this.job}`);
}
function Person(name, job) {
this.name = name;
this.job = job;
}
Person.prototype.greet = function() {
return greet.call(this);
}
const person = new Person('Richard', 'developer');
console.log(person.greet());
Виртуальный выделенный сервер (VDS) становится отличным выбором
Как правильно поступить, у меня есть интерфейс(ICommon<T>), есть его несколько реализаций (HelloInt:ICommon<int>, HelloDouble:ICommon<double>)Теперь я хотел...
Учительница задала Пете домашнее задание — в заданном тексте расставить ударения в словах, после чего поручила Васе проверить это домашнее...
В ListBox загонятеся отсортированный массив с числами по убываниюКак можно можно выделить первые 3 элемента другим цветом