查看以下代码结构:
myFunction(
_(myArray)
.filter({ keep: true })
.uniq('id')
.value()
);
myFunction()
将使用lodash进行某些数组转换的结果作为其参数。虽然我喜欢代码的样式,但我觉得很难调试并最终重构它以将lodash代码放在另一个函数中或首先将其分配给变量,然后将变量传递给myFunction()
。
您是否知道在不重构的情况下调试函数参数代码的有效方法?一些想法:
console.log
。.filter()
和.uniq()
答案 0 :(得分:5)
最好的方法是插入步骤:
.tap(console.log)
其他方式:
创建mixin函数
var debug = function (val) {
console.log(val);
return val;
}
_.mixin({'debug': debug})
并像
一样使用它_(myArray)
.debug()
.filter({ keep: true })
.debug()
.uniq('id')
.debug()
.value()
或者你可以在使用之前覆盖lodash函数,如
_.filter = _.wrap(_.filter, function(func, val) {
console.log(func(val));
return func(val);
});