# redux源码细读compose
# 上代码看效果
# 同步
function compose (...funcs) {
if (funcs.length === 0) {
return args => args
}
if (funcs.length === 1) {
return funcs[0]
}
return funcs.reduce((a, b) => (...args) => b(a(...args)))
}
// 千分符号
function thousandSplit (num) {
return String(num)
.replace(/(?=\B(?:\d{3})+\b)(\d{3}(\.\d+$)?)/g, ',$1');
}
// 保留两位数字向下取整
function floor (num) {
return (Math.floor(num * 100) / 100).toFixed(2);
}
var conts = 125885.365
console.log('正常我们的做法', thousandSplit(floor(conts)))
console.log('compose', compose(
floor,
thousandSplit
)(conts))
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
# 异步
;(async () => {
function compose (...funcs) {
if (funcs.length === 0) {
return args => args
}
if (funcs.length === 1) {
return funcs[0]
}
return funcs.reduce((a, b) => async (...args) => b(await a(...args)))
}
function fn1 (arg) {
return new Promise((resolve, reject) => {
setTimeout(() => {
arg += '_Promise_fn1'
console.log('fn1')
resolve(arg)
}, 1000)
})
}
function fn2 (arg) {
return new Promise((resolve, reject) => {
setTimeout(() => {
arg += '_Promise_fn2'
console.log('fn2')
resolve(arg)
}, 1000)
})
}
function fn3 (arg) {
arg += '_fn3'
return arg;
}
const result = compose(fn1, fn3, fn2)
result(1).then(res => {
console.log('异步返回', res)
})
})()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
只有运用才能真正掌握!
# 借鉴
- https://github.com/reduxjs/redux/blob/master/src/compose.ts
# 今日图
我以为我变秃了,也会变强的。后来我找到原因了,越洗越少