Оператор this возвращает ссылку на объект, являющийся текущим контекстом вызова. Это позволяет обращаться к свойствам "текущего" объекта: this.property.
Текущий объект не является жесткой фиксированным и зависит от
контекста вызова функции. Он является, своего рода, скрытым параметром.
Если ни один из этих способов не задействован, то this указывает на глобальный объект: в браузере это window.
Это происходит при вызове функции без объекта: myFunc(params).
При манипуляциях с DOM при помощи javascript, this обычно используется для работы с событиями. При этом значение this указывает на текущий DOM-элемент, в контексте которого вызван обработчик.
Привязка методов
Так как this не привязано жестко к объекту, то можно привязывать один и тот же метод к любым классам.
1
walk = function() { this.isWalking = true}
2
3
functionBird() { /*...*/}
4
functionRabbit() { /*...*/}
5
6
Bird.prototype.walk = Rabbit.prototype.walk = walk
7
8
newBird().walk() // в обоих случаях
9
newRabbit().walk() // this будет указывать на текущий объект