Постараюсь дать простое объяснение (без всяких асинхронных функций), когда конструкция self = this применяется в JavaScript. Создадим объект, в котором определены поле a = 2, b = 3 и функция fn, которая выводит в консоль поле a данного объекта при помощи ключевого слова this. В консоли мы ожидаемо получаем поле a объекта myObj, то есть 2. var myObj = { a : 2, b : 3, fn : function(){ console.log(this.a) // 2 } } myObj.fn() Но если внутрь функции fn вложить ещё одну функцию и в ней в консоль попытаться вывести поле b объекта myObj, мы получим в этом случае undefined. var myObj = { a : 2, b : 3, fn : function(){ console.log(this.a) // 2 var fn2 = function(){ console.log(this.b) // undefined } fn2() } } myObj.fn() Дело в том что, проверяется контекст функции, в которой встретилось ключевое слово this. В данном случае это функция fn2. Её контекст (ближайшие внешние фигурные скобки) относится к функции, а не к какому-либо объекту. И поэтому ключе