Больше пользы и лайв-контент в ТГ: - "У меня нет идей для пэт-проектов"- t.me/pomazkovjs/252 - Бесплатный курс по NextJS от его создателей - t.me/pomazkovjs/223 - Авторизация VS аутентификация (на пальцах) - t.me/pomazkovjs/221 В ТГ я пишу гораздо чаще, да и все апдейты всегда оказываются там в первую очередь. → t.me/pomazkovjs А еще у нас есть полезный чат, где царят уважение и взаимопомощь: t.me/+Hx6RaBT4Trw3ZjM6
Спасибо большое за такие классные уроки! Подробно, доступно, наглядно, структурировано, очень приятно слушать грамотную речь. Жду всегда новые материалы на канале, регулярно возвращаюсь к ранее просмотренным. Видео с замыканием 🔥
Огроменное тебе спасибище за твой неимоверный труд и время, которое ты тратишь, чтобы снимать такие интересные и суперкачественные ролики. Безумно нравится твоя подача материала: без воды, всё чётко по полочкам и с примерами. Желаю тебе продолжать в том же духе и вдохновлять ребят, начинающих этот нелёгкий путь, идти к своей мечте и не сдаваться). Ещё было бы интересно посмотреть видео на такие темы, как Promise, цепочки промисов, асинхронное программирование, HTTP/HTTPS, RESTful API, Prototypes, Event Loop.
Готовясь в 3 раз сменить место работы наткнулась впервые на ваш канал, такой подачи материала я еще не видела) очень круто) А подача лексического окружения в другом видео это просто что-то с чем-то, вроде так просто было всем остальным схематично донести суть, но никто этого не сделал. Большое человеческое спасибо)
Хотелось бы уточнить за пример вложенной функции на 5:38 ,myFunction не берет контекст из myFunction1,так как это противоречит тому,что контекст определяется в зависимости от вызова функции. Если вызывается просто функция без каких-либо доп методов ,new или dot нотации то по умолчанию this будет глобальным обьектом в нестрогом режиме.Вот например,что об пишется : Вложенные функции не наследуют значение this от внешних функций. Значение this в вложенной функции определяется контекстом, в котором она вызывается. Если вложенная функция вызывается как метод, то ее значение this будет объектом, на котором она вызывается. Если вложенная функция (т.е. не стрелочная функция) вызывается как функция, то ее значением this будет или глобальный объект (в нестрогом режиме), или undefined (в строгом режиме). Пример 1 : let o = { // Объект о m: function() { //метод m обьекта let self = this; // Сохранить значение this в переменной this === о // => true: this является объектом о f() ; //Теперь вызвать вспомогательную функцию f () function f () { //Вложенная функция f this === о // =>false: this является глобальным объектом или undefined self === о // true: self является внешним значением this } } }; o.m(); //Вызвать метод m на объекте о А если бы myFunction брала бы контекст из myFunction1,то у нас вышло бы что f брала бы контекст из анонимной функции присвоенной идентификатору m,и тогда бы эта функция ссылалась бы на сам обьект o ,а не на глобальный обьект
@@foxnadir ,Во -первых,то ,что ты написал ни как не противоречит моему.Во-вторых,я все правильно написал,в том числе к глобальному обьекту относится и windows в среде браузера.Но нельзя говорить за это постоянно,так как в той же Node уже не будет никакого windows)
Спасибо за труды, нравятся Ваши объяснения! Я смотрела объяснение this в стрелочных функциях у разных преподавателей, читала, но как доходило до практики - постоянно ошибалась. Вывод: не понимала объяснений. Сегодня благодаря Вам даже до меня дошло :D Спасибо еще раз!
Спасибо, что помогаешь разобраться в языке. На эту тему не так много детальных роликов, все люди лишь пробегаются по верхам, как будто темы легкие и не важные. Буду ждать следующих роликов
@@user-nf5yc7xz9b Я уже там подписчик. Проблема того канала заключается в том, что автор уничтожает современный подход к изучению JS. Может быть это и полезно, но что это даёт? Каждый раз на собеседованиях спорить и пытаться объяснять принципиально новую позицию? Это слишком муторно и сложно всё донести идеально правильно. Тем более на этом канале человек дошел до синьорской должности со знаниями абстракций по типу замыканий, контекста и прочей лабуды. Эффективнее всего, как мне кажется, понять эти абстракции и ими апеллировать на собеседованиях. По крайней мере собеседования не будут такими стрессовыми и сложными.
18:56 Не из-за того что .forEach вторым аргументом передает undefined в коллбек - внутри него this определяется как undefined. А все из-за того, что любая функция определенная в JavaScript по умолчанию является методом объекта (ВНИМАНИЕ!) window. И this тут ссылается именно к глобальному объекту window и ищет там свойство lastName. Вот оно там не определено и возвращает undefined. Это легко проверить написав в глобальной области this.lastName = "Виндоуское Иванов";
22:10 а внутри setTimeout *this* не определятся все потому что setTimeout изначально является методом windows объекта (как и было сказано вначале). Он тоже ссылается в глобальный объект своим this'ом.
"Это легко проверить написав в глобальной области this.lastName = "Виндоуское Иванов";" - или в самой функции выводить просто this. Можно еще добавить вторым параметром undefined и увидеть что ничего не поменяется, a если добавить другой объект, то поменяется только для logFullNames1.
@@pomazkovjs Кстати, интересно, а будет ли про Vue что-то? А то на UA-cam про него очень мало всего (понятно, что из-за React'а, который более используем)
Спасибо за видео. Для меня это сейчас уже не так страшно, но всё ещё страшно)). Хотелось бы посмотреть подробнее и про call, bind, apply. Я первый раз использовала конструктор для создания студентов (домашняя работа, да))), плюс там методы разные, куда я добавляла функции расчёта возраста, на каком курсе студент, полное имя, очень удобно получилось. Код стал чище в разы, легче и понятнее писался код
Привет. Изучаю сейчас js. Я на пути к фронтенд разработчику ахахах) Из многих видосов на ютубе по теории программирования очень мало таких видосов, которые хорошо сконструированы. То есть мало видосов, в которых их авторы обьъясняют всё поэтапно. А у тебя всё хорошо сконстурировано в видео и понятно всё от начала и до конца. Спасибо за твою работу)
Привет! Спасибо за то что делишься своими знаниями и классную подачу в видео, четко и понятно!) Думаю классно будет , если будет roadmap на ютубе, по твоему frontend roadmap там где ты выписал что нужно знать начинающему разработчику)
5:35 - myFunction не брала this у myFunction1, это работает только у стрелок, в данном случае компилятор инициировал this как Window потому что так заложено правилами языка
При разборе this в стрелочной функции 19:15 что-то не сходится. Я вызвал просто "this" в форыче обычной функции в примере, и он определен - [obj Window], а не undefined. В примере возникает undefined из-за того, что у глоб объекта нету поля lastName( window.lastName = undefined)
Благодаря конспекту по var/let/const с бусти, спустя 1,5 недели перекапывания интернета наконец-то понял в чем суть TDZ и когда она образуется! Немного не в тему, но все же, огромное спасибо! Седи всех ютуб-лекторов, твой контент самый легкоусваиваемый
Больше пользы и лайв-контент в ТГ:
- "У меня нет идей для пэт-проектов"- t.me/pomazkovjs/252
- Бесплатный курс по NextJS от его создателей - t.me/pomazkovjs/223
- Авторизация VS аутентификация (на пальцах) - t.me/pomazkovjs/221
В ТГ я пишу гораздо чаще, да и все апдейты всегда оказываются там в первую очередь.
→ t.me/pomazkovjs
А еще у нас есть полезный чат, где царят уважение и взаимопомощь: t.me/+Hx6RaBT4Trw3ZjM6
Спасибо большое за такие классные уроки! Подробно, доступно, наглядно, структурировано, очень приятно слушать грамотную речь. Жду всегда новые материалы на канале, регулярно возвращаюсь к ранее просмотренным. Видео с замыканием 🔥
Легенда вернулась!
Твой урок по замыканиям лучший в ютубе)
Спасибо!)) 🔥
Лесть, такое себе. Но да - автор молодец. Плюс ещё один блогер, который толково объясняет. Просто и по полочкам.
@@bjol_Dg лесть не лесть, но мне реально его уроки помогают
А смотрел я много разных авторов
Если человек старается, то пусть видит обратную связь
@@bjol_Dg ахаха, какая лесть? Человек свое субъективное мнение написал))
@@johnnyzhuravlev7334 ахахаха, не надо никуда лезть))
Отдельное видео по call, apply, bind будет очень полезным. Спасибо за работу и старания)
Огроменное тебе спасибище за твой неимоверный труд и время, которое ты тратишь, чтобы снимать такие интересные и суперкачественные ролики. Безумно нравится твоя подача материала: без воды, всё чётко по полочкам и с примерами. Желаю тебе продолжать в том же духе и вдохновлять ребят, начинающих этот нелёгкий путь, идти к своей мечте и не сдаваться).
Ещё было бы интересно посмотреть видео на такие темы, как Promise, цепочки промисов, асинхронное программирование, HTTP/HTTPS, RESTful API, Prototypes, Event Loop.
Большое спасибо за такой приятный комментарий! Буду стараться 🔥
Готовясь в 3 раз сменить место работы наткнулась впервые на ваш канал, такой подачи материала я еще не видела) очень круто)
А подача лексического окружения в другом видео это просто что-то с чем-то, вроде так просто было всем остальным схематично донести суть, но никто этого не сделал. Большое человеческое спасибо)
Очень крутые видосы! С хорошим и доступным объяснением, ждем видео по call, apply, bind! Спасибо)
Очень доступно и все в одном месте! не надо шарить всю документацию в поисках, а где еще что могло спрятаться по этой теме!)
Красава! Решал задачу на КодВорс, не решил. Спустя 2 недели смотрю это видео и понимаю, что apply это то,что было нужно! Благодарю.
Хотелось бы уточнить за пример вложенной функции на 5:38 ,myFunction не берет контекст из myFunction1,так как это противоречит тому,что контекст определяется в зависимости от вызова функции.
Если вызывается просто функция без каких-либо доп методов ,new или dot нотации то по умолчанию this будет глобальным обьектом в нестрогом режиме.Вот например,что об пишется :
Вложенные функции не наследуют значение this от внешних функций. Значение this в вложенной функции определяется контекстом, в котором она вызывается. Если вложенная функция вызывается как метод, то ее значение this будет объектом, на котором она вызывается. Если вложенная функция (т.е. не стрелочная функция) вызывается как функция, то ее значением this будет или глобальный объект (в нестрогом режиме), или undefined (в строгом режиме).
Пример 1 :
let o = { // Объект о
m: function() { //метод m обьекта
let self = this; // Сохранить значение this в переменной
this === о // => true: this является объектом о
f() ; //Теперь вызвать вспомогательную функцию f ()
function f () { //Вложенная функция f
this === о // =>false: this является глобальным объектом или undefined
self === о // true: self является внешним значением this
}
}
};
o.m(); //Вызвать метод m на объекте о
А если бы myFunction брала бы контекст из myFunction1,то у нас вышло бы что f брала бы контекст из анонимной функции присвоенной идентификатору m,и тогда бы эта функция ссылалась бы на сам обьект o ,а не на глобальный обьект
Чуть-чуть неправильно, но в целом неплохо. Читай мой коммент снизу
@@foxnadir ,Во -первых,то ,что ты написал ни как не противоречит моему.Во-вторых,я все правильно написал,в том числе к глобальному обьекту относится и windows в среде браузера.Но нельзя говорить за это постоянно,так как в той же Node уже не будет никакого windows)
Огромное тебе спасибо !
Реально простыми словами, с использованием примеров - идеально !
Спасибо за труды, нравятся Ваши объяснения! Я смотрела объяснение this в стрелочных функциях у разных преподавателей, читала, но как доходило до практики - постоянно ошибалась. Вывод: не понимала объяснений. Сегодня благодаря Вам даже до меня дошло :D Спасибо еще раз!
Отличное видео! Всё очень понятно! Благодарю!
Спасибо, что помогаешь разобраться в языке. На эту тему не так много детальных роликов, все люди лишь пробегаются по верхам, как будто темы легкие и не важные. Буду ждать следующих роликов
Так и автор пробегается по верхам , найдите канал as for js ,вот там по настоящему глубоко разбирают js
@@user-nf5yc7xz9b Я уже там подписчик. Проблема того канала заключается в том, что автор уничтожает современный подход к изучению JS. Может быть это и полезно, но что это даёт? Каждый раз на собеседованиях спорить и пытаться объяснять принципиально новую позицию? Это слишком муторно и сложно всё донести идеально правильно. Тем более на этом канале человек дошел до синьорской должности со знаниями абстракций по типу замыканий, контекста и прочей лабуды. Эффективнее всего, как мне кажется, понять эти абстракции и ими апеллировать на собеседованиях. По крайней мере собеседования не будут такими стрессовыми и сложными.
Спасибо! Все просто, понятно и полезно.
18:56 Не из-за того что .forEach вторым аргументом передает undefined в коллбек - внутри него this определяется как undefined. А все из-за того, что любая функция определенная в JavaScript по умолчанию является методом объекта (ВНИМАНИЕ!) window. И this тут ссылается именно к глобальному объекту window и ищет там свойство lastName. Вот оно там не определено и возвращает undefined. Это легко проверить написав в глобальной области this.lastName = "Виндоуское Иванов";
22:10 а внутри setTimeout *this* не определятся все потому что setTimeout изначально является методом windows объекта (как и было сказано вначале). Он тоже ссылается в глобальный объект своим this'ом.
"Это легко проверить написав в глобальной области this.lastName = "Виндоуское Иванов";" - или в самой функции выводить просто this. Можно еще добавить вторым параметром undefined и увидеть что ничего не поменяется, a если добавить другой объект, то поменяется только для logFullNames1.
Лайк авансом =), ну и конечно же коммент в поддержку канала! Арсений не забывай про видосы!!! Контент супер!!!
Спасибо за поддержку, стараюсь! 💪🏼
@@pomazkovjs Кстати, интересно, а будет ли про Vue что-то? А то на UA-cam про него очень мало всего (понятно, что из-за React'а, который более используем)
Особенно круто, что ты разбираешь не попсовые темы
Автор, выражаю своё спасибо лайком, и подпиской. Ты мне очень помог разобраться с this!
Понятно и доходчиво. Четко !
Спасибо! Убил день + пока не посмотрел твое видео))) Теперь хоть что-то стало понятно!!! This - жив 😄
Это качественный и полезный контент
Братан, хорош, давай, давай, вперёд! Контент в кайф, можно ещё? Вообще красавчик! Можно вот этого вот почаще?
Спасибо большое за ваш труд. Лучший канал по JS. Жаль, что забросили.
Я ничего не забрасывал, просто редко выкладываю видео :)
В тг, например, можно видеть посты чаще: t.me/pomazkovjs
@@pomazkovjs круто, буду следить тогда. Если можно подумайте над темами Event Loop или базовые фундаментальные знания для программистов.
Можно сразу тысячу лайков поставить, супер годный контент!
Отличный ролик, представляю сколько времени на него ушло :)
Спасибо!) Времени ушло действительно много, но я уверен, что все не зря, и этот разбор многим поможет 🙌
Твои видео всегда дают простое понимание сложных вещей. Спасибо.
Пили подробный видос про call, apply
Спасибо за годный контент, всё четко и по делу
Очень помог. Спасибо!
очень качественный материал,спасибо!
Мне нравится твои уроки!
Спасибо за видео. Для меня это сейчас уже не так страшно, но всё ещё страшно)). Хотелось бы посмотреть подробнее и про call, bind, apply.
Я первый раз использовала конструктор для создания студентов (домашняя работа, да))), плюс там методы разные, куда я добавляла функции расчёта возраста, на каком курсе студент, полное имя, очень удобно получилось. Код стал чище в разы, легче и понятнее писался код
спасибо за доступный урок
большое спасибо! очень полезная информация
Спасибо за твой канал. Благодаря тебе я снова начал программировать спустя 3 года
Воу, огонь! Рад, что помог найти мотивацию и вдохновение)
Привет, крутые видео. Очень жду видео про асинхронности.
Привет. Изучаю сейчас js. Я на пути к фронтенд разработчику ахахах) Из многих видосов на ютубе по теории программирования очень мало таких видосов, которые хорошо сконструированы. То есть мало видосов, в которых их авторы обьъясняют всё поэтапно. А у тебя всё хорошо сконстурировано в видео и понятно всё от начала и до конца. Спасибо за твою работу)
Спасибо за контент! Будет в ближайшем будущем видос про прототипы?
Хорошее видео, спасибо
Про промисы хотелось бы разбор и про асинхронность
Спасибо за видео, очень хорошо разьяснил
Только сегодня разбирался с this, а тут как раз это видео)) Я подписчик с замыкания))
Идеальный тайминг 🔥
Спасибо, очень познавательное видео.
Спасибо за видео!
мне видео показалось полезным, я прожал лайк и написал об этом в комментариях)0)
Нереальное видео, именно благодаря таким как вы джуны готовятся к собеседованиям, вечный +реп
и не устраиваются. АХАХАХАХАХА. Рынок переполнен настолько, что устроиться на джуна вообще нереально
Спасибо очень хороший разбор.
Супер! Сделай, пожалуйста, про промисы
Привет! Спасибо за крутые объяснения! Очень хотелось бы разобрать в таком духе промисы, async/await
Привет!
Спасибо за то что делишься своими знаниями и классную подачу в видео, четко и понятно!)
Думаю классно будет , если будет roadmap на ютубе, по твоему frontend roadmap там где ты выписал что нужно знать начинающему разработчику)
Спасибо, действительно понятно!
спасибо
Спасибо! Делай больше видео!!!!
видео крутое, разбор четкий!
Хотелось бы услышать про асинхронность в JS в твоем исполнении, очено хорошо объясняешь 🔥🤝
Это видео кажется мне полезным) Разобрался, почему же this может выводить мне пустоту или же глобальный объект
Спасибо за видео 😊
Отличное видео!👍
Спасибо за видос
Огромное вам спасибо
Хорошее видео мне помогло
Это прям огонь 🔥 спасибо.
спасибо за урок
Арсений, спасибо огромное за обучающие видео! Всё максимально подробно, интересно и, что самое главное, понятно!
Отдельное видео по call, apply, bind пожалуйста.
Комментарий для продвижения, так держать
Годный контент!
ждем подробное объяснение про call,bind и apply также хотелось бы увидеть объяснение про конструкторы и классы.
суперские объяснения, смотрю уже третий видос и это один из лучших каналов по js
Добрый час, спасибо за видео, было бы интересно ролик про Primise и fetch
Круто! Спасибо
Спасибо большое, это лучшее видео про this💐
Спасибо) Супер!
Полезно. Подписался
единственный человек который объяснил все четко и грамотно! спасибо огромное!
Круть, еще бы про Event Loop, prototype, async 😔
5:35 - myFunction не брала this у myFunction1, это работает только у стрелок, в данном случае компилятор инициировал this как Window потому что так заложено правилами языка
Видео показалось мне полезным. Поэтому я, как наставлял Автор, прожал Like и пишу об этом в комментариях..
Конечно же лайк
Крутое видео!!!
просто красавчик, оч крутые видео, топ контент)
не останавливайся
Спасибо огромное за твой труд!!! Объяснения очень понятные👏👏👏 Продолжай пожалуйста снимать.
При разборе this в стрелочной функции 19:15 что-то не сходится. Я вызвал просто "this" в форыче обычной функции в примере, и он определен - [obj Window], а не undefined. В примере возникает undefined из-за того, что у глоб объекта нету поля lastName( window.lastName = undefined)
Арсений, разбери вот эти интересные темы: promise, декораторы, каррирование, веб-воркеры.
Думаю, что с твоим умением объяснять, будет бомба контент)
Приятный голос, не раздражающий ) Спасибо за информацию!
Видео супер! Понятно все! По полочкам!
Ждем видео про промисы и прототипы
спасибо за видос по замыканиям - я хоть через год в разработке норм понял. сделай плиз видос с примерами call bind apply
Спасибо за коммент! Сделаю 💪🏻
спасибо за контент =)
Отличный контент
видео полезно!
Спасибо большое за Ваши видео, они очень помогают глубже понимать материал.
Видео по call, apply, bind будет полезным !!🤓
Ждем видео про call и apply
Одно из лучших видео на ютубе про 'this' в js
У тебя очень крутые видео, и очень понятные, можешь пожалуйста сделать видео про методы массивов, строк и объектов. Буду очень благодарен)
Твои видео всегда дают простое понимание сложных вещей. Спасибо.
Благодаря конспекту по var/let/const с бусти, спустя 1,5 недели перекапывания интернета наконец-то понял в чем суть TDZ и когда она образуется! Немного не в тему, но все же, огромное спасибо! Седи всех ютуб-лекторов, твой контент самый легкоусваиваемый
Очень здорово объясняешь! Спасибо тебе!!
Ура, я ждала это видео! Спасибо!