我仍在学习Ramda,经常难以将看似简单的lamda函数转换为无点的纯Ramda函数。这是一个简单的示例:
export const consoleTap = arg =>
R.compose(
R.tap,
R.curryN(2, console[arg])
);
export const errorTap = consoleTap("error");
export const logTap = consoleTap("log");
// example usage
R.map(logTap("Value"))([1, 2]) // Results in printing "Value 1" "Value 2"
函数运行正常,我什至为它们编写了测试。我只是觉得consoleTap可以写成没有意义的东西,只是有些我没有正确看到或理解。可以重写功能吗?
答案 0 :(得分:0)
我无法提出一种看上去不太复杂的无点版本。我认为您的财产已经很不错了。
我唯一的建议是将事情分解:将日志记录与tap
分开。您可以自己重用日志的“前缀”版本:
const logWith = (method, prefix) => curryN(2, console[method])(prefix);
const log = logWith('log', 'INFO: ');
const error = logWith('error', 'ERR: ');
log(10); // INFO: 10
error(10); // ERR: 10
并带有tap
:
const logTap = tap(logWith('error', 'ERR: '));
logTap(10);
// ERR: 10
// => 10
答案 1 :(得分:0)
您遇到的问题是由于R.tap
不可变。
// tap is a unary function
const log = R.tap(console.log);
// logs only `1`
log(1, 2, 3, 4);
<script src="https://cdnjs.cloudflare.com/ajax/libs/ramda/0.26.1/ramda.js" integrity="sha256-xB25ljGZ7K2VXnq087unEnoVhvTosWWtqXB4tAtZmHU=" crossorigin="anonymous"></script>
因此您无法执行log('Value is, 1)
,一种解决方法是将R.unapply
的tap参数分组,然后通过R.apply
将它们应用回记录器。
一个简单的解决方案可能是在为记录器提供前缀之后调用R.tap
:
const logger = R.pipe(
R.prop(R.__, console),
R.curryN(2),
);
const error = logger('error');
const log = logger('log');
const result = R.map(
R.tap(log('value is')),
)([1, 2]);
// tap didn't alter any item inside the functor.
console.log('result is', result)
<script src="https://cdnjs.cloudflare.com/ajax/libs/ramda/0.26.1/ramda.js" integrity="sha256-xB25ljGZ7K2VXnq087unEnoVhvTosWWtqXB4tAtZmHU=" crossorigin="anonymous"></script>