如何有效调试方法链式函数参数?
How to effectively debug method chained function arguments?
看看下面的代码结构:
myFunction(
_(myArray)
.filter({ keep: true })
.uniq('id')
.value()
);
myFunction()
将使用 lodash 进行一些数组转换的结果作为其参数。虽然我喜欢代码的风格,但我发现很难调试并最终重构它以将 lodash 代码放在另一个函数中或先将其分配给变量,然后将变量传递给 myFunction()
.
您是否知道无需重构即可调试函数参数代码的有效方法?一些想法:
- 照原样,无法添加
console.log
的正确位置。
- 在 Chrome DevTools 中无法设置断点,例如在
.filter()
和 .uniq()
之间
最好的方法是插入步骤:
.tap(console.log)
其他方式:
创建混合函数
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);
});
看看下面的代码结构:
myFunction(
_(myArray)
.filter({ keep: true })
.uniq('id')
.value()
);
myFunction()
将使用 lodash 进行一些数组转换的结果作为其参数。虽然我喜欢代码的风格,但我发现很难调试并最终重构它以将 lodash 代码放在另一个函数中或先将其分配给变量,然后将变量传递给 myFunction()
.
您是否知道无需重构即可调试函数参数代码的有效方法?一些想法:
- 照原样,无法添加
console.log
的正确位置。 - 在 Chrome DevTools 中无法设置断点,例如在
.filter()
和.uniq()
之间
最好的方法是插入步骤:
.tap(console.log)
其他方式:
创建混合函数
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);
});