Продолжаем говорить о функциональном программировании и сегодня речь пойдет о следующих терминах: композиция функций, каррирование и авто-каррирование.
Композиция функций (Function Composition) - соединение функций для формирования новой функции, в которой результат первой функции передается в качестве аргумента во вторую функцию. Математически это выглядит так:
Каррирование(Curring) - конвертация функции из функции, которая принимает несколько входящих аргументов, в функцию, которая принимает один аргумент за раз.
Каждый раз вызывая функцию с одним аргументом, мы получаем новую функцию, до тех пор пока не получим все аргументы:
Сегодня в ссылке отличный видео курс по функциональному программированию.
#функциональное_программирование
Композиция функций (Function Composition) - соединение функций для формирования новой функции, в которой результат первой функции передается в качестве аргумента во вторую функцию. Математически это выглядит так:
F(x) = g(f(y))
В коде так:
const compose = (f, g) => (a) => f(g(a)) // Definition
const floorAndToString = compose((val) => val.toString(), Math.floor) // Usage
floorAndToString(121.212121) // '121'
Каррирование(Curring) - конвертация функции из функции, которая принимает несколько входящих аргументов, в функцию, которая принимает один аргумент за раз.
Каждый раз вызывая функцию с одним аргументом, мы получаем новую функцию, до тех пор пока не получим все аргументы:
const sum = (a, b) => a + b
const curriedSum = (a) => (b) => a + b
curriedSum(40)(2) // 42.
const add2 = curriedSum(2) // (b) => 2 + b
add2(10) // 12
Автоматическое каррирование (Auto Currying) - преобразование функции, принимающей несколько аргументов, в новую функцию. В новой функции, если передавать меньшее количество аргументов, то она вернет новую функцию, которая ожидает оставшиеся аргументы. В популярном фреймворке ramda есть специальная функция curry, реализующая автоматическое каррирование.
const add = (x, y) => x + y
const curriedAdd = _.curry(add)
curriedAdd(1, 2) // 3
curriedAdd(1) // (y) => 1 + y
curriedAdd(1)(2) // 3
Сегодня в ссылке отличный видео курс по функциональному программированию.
#функциональное_программирование
Давайте поговорим сегодня о новых терминах функционального программиста: идемпотентность, предикат и бесточечная нотация.
Идемпотентность (idempotent) - функция идемпотента если ее повторное использование не меняет результат.
Предикат (predicate) - функция, которая возвращает булево значение в зависимости от передаваемого значения, в качестве примера можно привести callback функции в filter.
Бесточечная нотация (Point-Free Style) - стиль написания функций, при котором не явно указывается количество используемых аргументов. Такая нотация часто используется для каррирования или для других функций высшего порядка.
Функция
Определения с бесточечной нотацией выглядят как обычные присваивания без
#функциональное_программирование
Идемпотентность (idempotent) - функция идемпотента если ее повторное использование не меняет результат.
f(f(x)) ≍ f(x)
Math.abs(Math.abs(10))
sort(sort(sort([2, 1])))
Предикат (predicate) - функция, которая возвращает булево значение в зависимости от передаваемого значения, в качестве примера можно привести callback функции в filter.
const predicate = (a) => a > 2
;[1, 2, 3, 4].filter(predicate) // [3, 4]
Бесточечная нотация (Point-Free Style) - стиль написания функций, при котором не явно указывается количество используемых аргументов. Такая нотация часто используется для каррирования или для других функций высшего порядка.
// Given
const map = (fn) => (list) => list.map(fn)
const add = (a) => (b) => a + b
// Then
// Not points-free - `numbers` is an explicit argument
const incrementAll = (numbers) => map(add(1))(numbers)
// Points-free - The list is an implicit argument
const incrementAll2 = map(add(1))
Функция
incrementAll определяет и использует параметр numbers, так что она не использует бесточечную нотацию. incrementAll2 просто комбинирует функции и значения, не упоминая аргументов. Она использует бесточечную нотацию.Определения с бесточечной нотацией выглядят как обычные присваивания без
function или =>.#функциональное_программирование
Совет профессионала:
Избегайте релизить ваше ПО. Просто оставьте все на localhost.
Релизы приводят к неизбежным проблемам не только в праздники и выходные, но и в рабочие дни.
Избегайте релизить ваше ПО. Просто оставьте все на localhost.
Релизы приводят к неизбежным проблемам не только в праздники и выходные, но и в рабочие дни.
Очередной проект написанный на javanoscript, который может быть полезен в повседневной жизни.
Wiki для команды - легко с Outline.
https://github.com/outline/outline
Wiki для команды - легко с Outline.
https://github.com/outline/outline
GitHub
GitHub - outline/outline: The fastest knowledge base for growing teams. Beautiful, realtime collaborative, feature packed, and…
The fastest knowledge base for growing teams. Beautiful, realtime collaborative, feature packed, and markdown compatible. - outline/outline
Применение Saga паттерна для работы с побочными эффектами - https://redux-saga.js.org
Уверенно выходим из режима #післясвят и напоминаем, что на 22 января уже запланирована первая в этом году встреча. Ожидаем в гости Martin Chaov, Software Architect SBTech и Александра Поштарука, Senior Front-end developer ITecGurus 😱 Тема первой встречи очень релевантна построению плана по личному росту на год — Growing Seniority 😉 http://mathrandom.com/growing_seniority.
Как резали ли бы ножницы ✂️ из иконок, если бы они были реальными - https://wh0.github.io/2020/01/02/scissors.html
Отличный инструмент для рисования диаграмм в стиле "от руки". Открытый код и удобный online сервис в комплекте.
https://www.excalidraw.com/
https://www.excalidraw.com/
Альтернативная moment.js библиотека для работы с датами, размер библиотеки 2kB. API повторят API moment.js.
Учебные материалы для изучения контейниризации с Docker.