- 一元函数: (input) => output
- 高阶函数: (a) => (b) => c
//before
const handleSumbit = async formValues => {
const values = await validate(formValues)
const actualValues = await transform(values)
const result = await post(acutalValues)
return result
}
//after
const handleSumbitFp = asyncFlow(validate, transform, post)
flow
参数都是函数, 返回一个函数使用场景:
当下一个函数只需上一个函数的返回值时
const getLength = (x: string) => x.length
const increase = (x: number) => x + 1
const workFlow = flow(getLength, increase)
const result = workFlow('FP') // result = 3
pipe
第一个参数是值, 后面的参数都是函数使用场景:
分发依赖
const getLength = (x: string) => x.length
const increase = (x: number) => x + 1
const result = (input: string, step: number) =>
pipe('FP', getLength, increaseWith(step)) // result = 3
asyncFlow
所有参数都是异步函数(第一个是,后面不是也行), 执行后返回一个异步函数
const workFlow = asyncFlow(fetch, r => r.json(), console.log)
workFlow('http://xx.json')
asyncPipe
第一个参数是一个Promise
值, 后面的参数都是函数
const result = await asyncPipe(fetch('http://xx.json'), r => r.json())
const datas = [
{ kind: 'frontend', lib: 'React' },
{ kind: 'backend', lib: 'Express' },
]
const result = pipe(
datas,
groupBy(v => v.kind),
g => g.values(),
toList,
flat,
map(v => v.lib)
)
-
处理数组 (常用的)
map
|filter
|flat
|concat
|unique
|last
|first
-
处理对象
pick
|omit
-
条件判断
maybe
|fallback
|notNull
|isEmpty
|isZero
-
其他
peek
|invoke
waitAll
= Promise.all()
toList
= Array.from()
unique
= new Set()
pickFn
| omitFn
| groupByFn
| separeByFn
const validate = () => {
throw new Error('invalidate')
}
const post = async data => axios.post('/api', data)
const submit = flow(validate, post)
submit({}).catch(e => {
//捕捉不到错误, 因为 `validate` 不是异步函数
})