----------------------------------- Функции высшего порядка (HigherOrderFunctions)---------------------------------- 00:00:00 Определение 00:02:03 Математическая функция 00:05:57 Функция обратного вызова (callback) 00:09:33 Замыкание 00:10:51 Цепочка вызовов 00:12:40 Сохранение кэша с помощью замыкания 00:18:29 Добавление функции поведение логирования 00:21:45 Обобщение ---------------------------------- Применение функций высшего порядка --------------------------------------------------- 00:22:45 Сallback 00:25:32 Сallback асинхронной функции считывание файла 00:28:36 Сallback именованный 00:33:01 Сallback-timer 00:36:20 Сallback-timer-curry 00:38:59 Listener 00:41:10 Listener-timer 00:46:59 Event 00:53:45 Event-imitter 00:57:48 Deferred object (отложенный объект) 01:01:31 Errors
@maksymovych_maksym4 жыл бұрын
дякую
@НикитаПогребной-я4э3 жыл бұрын
этот материал лучше большинства платных курсов! спасибо вам огромное!
@TimaGixe Жыл бұрын
Чудова лекція! Дякую за вашу працю!
@aleksprimetv3 жыл бұрын
Тимур спасибо за лекцию и за твой труд! Комент для продвижения.
@TimurSevimli2 жыл бұрын
Спасибо за лекции. Вполне логично но почему то не когда не думал и не видел что можно замкнуть объект в функции и использовать его с разными вызовами функции что бы ссылки были разные. Спасибо за идею и за знаний Тимур Гафарович!
@rtfmetal5 жыл бұрын
Офигенная лекция! Примеры хорошие! Спасибо!
@DimitarRad2 жыл бұрын
Даже не начав смотреть данное видео, сразу лайк и коммент ;)
@maksymovych_maksym4 жыл бұрын
Дуже класний метаріал, дякую! Велика подяка, за таку велику кількість дуже корисного матеріалу!
@Max-kr4ie4 жыл бұрын
Ох буду пересматривать и не один раз.
@Yerevan23942 жыл бұрын
Лучший материал по js, спасибо огромное
@TheTexPro2 жыл бұрын
Спасибо большое! очень интересно и познавательно.
@TimurShemsedinov2 жыл бұрын
Стараемся, все самое лучшее только сейчас и только для вас, совершенно бесплатно
@КурашовЕвгений-н3ю5 жыл бұрын
круто. Спасибо
@Antonio-fm1sq3 жыл бұрын
Спасибо!
@СтройС-я9о2 жыл бұрын
34:07 =))) "Тяжелое детство в браузере"
@RK-gm4pd4 жыл бұрын
как всегда классная лекция с ценним содержимим. жаль что не инглиш. "parameter needed" - немного повеселило )). никада такова не слишал ))
@Aristocrator4 жыл бұрын
46:50 почему рекурсия? Разве это не цикл?
@TimurShemsedinov4 жыл бұрын
Это не цикл и не рекурсия, это итерация, но она происходит циклически (т.е. повторяющиеся действия для каждого элемента) и рекурсивно (т.е. когда доходим до конца, то начинаем сначала). Я неправильно применил термин. Если бы там был setTimeout или setImmediate, то тогда бы это точно была рекурсия через события, внутри функции содержался бы непрямой вызов самой себя, отложенный во времени, а тут setImmediate как раз от этого нас избавляет, внутри setImmediate кстати реализована рекурсия, потому, что он там внутри делает аналог setTimeout каждый раз.
@TimurSevimli2 жыл бұрын
Тимур Гафарович, я делаю повторение материала то что проходил прошлой недели и в этот раз более лучше понял на счет асинхронности в JS с помощью примера 7-listener-timer.js. Но если использовать какой то таймер кроме setInterval тогда получаем результат только первого итерирование и всего один раз. То есть варианты кроме setInterval решают вопрос с асинхронности но не решают работать с listener. Может я что то не правильно понял 🤷♂
@pavpav15735 жыл бұрын
Подскажите , что в контексте JS означает термин «лямбда» ? Или подскажете в какой вашей лекции это можно подсмотреть ?
@TimurShemsedinov5 жыл бұрын
Функции, у которых есть только лексический контекст и нет объектного (нет this). Например: const twice = x => x * 2;
@jamjam33372 жыл бұрын
👏
@ЕвгенийКраев-я2ж3 жыл бұрын
Тимур, Ваш плейлист "основы программирования", он выстроен по порядку или там просто "накиданы" лекции>?
@TimurShemsedinov3 жыл бұрын
Смотреть нужно в этом порядке github.com/HowProgrammingWorks/Index
@vitalaskompulat50532 жыл бұрын
а второй поток можно создать в js чтобы обойти большой массив вместо setInterval?
@TimurShemsedinov2 жыл бұрын
Можно, но массив должен быть типизированный и по этому есть лекция и по потомкам тоже
@Михайло-р9р3 жыл бұрын
Пример 8-event.js на 48:39 , не проще сделать функцию adder которая принимает сразу три аргумента initial value , max , function ?
@Nikitosss915 жыл бұрын
Ничего не понятно, но очень интересно 🌚
@romankotenko74 жыл бұрын
привет 26:19 лямбда разве не третий аргумент?
@maks4941 Жыл бұрын
function curry(fn, ...args) { const curried = (...moreArgs)=> fn.length
@maks4941 Жыл бұрын
function curry(fn, ...args) =>(...moreArgs)=> fn.length
@ДмПРКП4 жыл бұрын
Блин не могу понять к чему здесь bind const sum = (a, b, callback) => callback(a + b); sum(5, 2, console.log.bind(null, 'sum(5, 2) =')); Как вообще это работает?)) Пытаюсь sum(5, 2, (err, data)=>{ if (err) throw new Error console.log(data) }); - не работает как мне вернуть результат? подскажите пожалуйста
@ДмПРКП4 жыл бұрын
let callback = function(x, y) console.log(x + y) const sum = (a, b, callback) => callback(a, b); sum(5, 2, callback); - вот так работает. А как console.log() и bind работает все равно не понял
@TheTexPro2 жыл бұрын
@@ДмПРКП привет! bind позволят передать аргумент в функцию НЕ вызывая ее саму, потому в примере из лекции сперва вылезает строчка, а затем результат сложения. Callback отрабатывает со строчкой раньше и затем уже показывает результат, bind впихнул аргумент в callback перед результатом сложения
@ДмПРКП2 жыл бұрын
@@TheTexPro я уже теперь знаю, мой джаваскрипт не был так силён, год назад))
@ДмПРКП2 жыл бұрын
@@TheTexPro но все равно спасибо!
@maks4941 Жыл бұрын
@@ДмПРКП если вдруг кто не знает смотрте прошлую лекцию: kzbin.info/www/bejne/hHWbfIRrrc-ebdE
@alexandrrohov68723 жыл бұрын
Этот курс покруче известного CS50 ))
@TimurShemsedinov3 жыл бұрын
ну CS50 это же не для профессиональных программистов, CS50 это ознакомительный курс для гуманитариев и домохозяек, он так и позиционируется
@RisDeep5 жыл бұрын
Слышно дыхание лектора, как будто одышка при какой-то болезни. Сам болел пневмонией поэтому бросается в глаза*