如何優雅地 Debug Callback ?

栏目: JavaScript · 发布时间: 5年前

内容简介:ECMAScript 是大量使用 Callback 的語言,實務上我們常想針對 Callback 加以VS Code 1.33.1Quokka 1.0.209

ECMAScript 是大量使用 Callback 的語言,實務上我們常想針對 Callback 加以 console.log() 協助 Debug,該如何優雅地使用 console.log() 呢 ?

Version

VS Code 1.33.1

Quokka 1.0.209

ECMAScript 2015

Callback

實務上對於 callback 可能有兩種情境需要 debug:

  • 得知 callback 的 parameter 值
  • 確認 callback 是否被執行過

得知 Callback 的 Parameter 值

import { map } from 'ramda';

let data = [1, 2, 3];

let fn = map(x => x * 2);
console.dir(fn(data));

map() 使用 callback,我們想得知 x 到底為多少 ?

如何優雅地 Debug Callback ?

import { map } from 'ramda';

let data = [1, 2, 3];

let fn = map(x => {
  console.log(x);
  return x * 2;
});
console.dir(fn(data));

原本 callback 只有 x => x + 2 ,因此不需 {}return ,這是 arrow function 特色。

但為了加上 console.log() ,就只能加上 {}return 而打回原形,不能再使用 arrow function。

如何優雅地 Debug Callback ?

import { map } from 'ramda';

let data = [1, 2, 3];

let fn = map(x => console.log(x) || x * 2);
console.dir(fn(data));

可將 console.log() 搭配 || ,接上 inc() ,如此不需 {} ,也不需要 return ,還能繼續使用 arrow function。

因為 console.log() 會回傳 undefined ,視為 falsy value,而 ||false 才會繼續執行,所以一定會繼續執行 x * 2

如何優雅地 Debug Callback ?

確認 Callback 是否被執行過

import { Maybe } from 'crocks';

let inc = n => n + 1;
let getResult = val => val.map(n => inc(n));

let result = getResult(Maybe.Nothing());
console.log(result);

getResult() 傳入 Nothing 時,結果也是 Nothing ,此時對於 Maybe.map() 的 callback 是否被執行過,我們會有疑慮。

如何優雅地 Debug Callback ?

import { Maybe } from 'crocks';

let inc = n => n + 1;
let getResult = val => val.map(n => {
  console.log('Calling inc()');
  return inc(n);
});

let result = getResult(Maybe.Nothing());
console.log(result);

原本 callback 只有 inc() ,因此不需 {}return ,這是 arrow function 特色。

但為了加上 console.log() ,就只能加上 {}return 而打回原形,不能再使用 arrow function。

如何優雅地 Debug Callback ?

證明傳入 Nothing 時,callback 完全沒有執行,因此沒有印出 Calling inc()

若看不懂 Maybe 沒關係,本文主要是討論 console.log() 的寫法

import { Maybe } from 'crocks';

let inc = n => n + 1;
let getResult = val => val.map(n => console.log('Calling inc()') || inc(n));

let result = getResult(Maybe.Nothing());
console.log(result);

可將 console.log() 搭配 || ,接上 inc() ,如此不需 {} ,也不需要 return ,還能繼續使用 arrow function。

因為 console.log() 會回傳 undefined ,視為 falsy value,而 ||false 才會繼續執行,所以一定會繼續執行 inc()

如何優雅地 Debug Callback ?


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

区块链

区块链

(美)梅兰妮·斯万 / 新星出版社 / 2016-1-1 / 50元

本书以全景式的方式介绍了区块链相关技术目前发展状况和未来技术衍生方向的展望,作者认为区块链技术可能是继互联网发明以来最大的技术革命。全书从比特币的概念模型和区块链技术正开始结合的方面讨论了三个不同的结构层面:区块链1.0、2.0和3.0。首先介绍了比特币和区块链技术的基本定义和概念,还有作为区块链1.0应用核心的货币和支付系统。其次,区块链2.0将超越货币范畴,会发展为货币市场和金融应用,类似于合......一起来看看 《区块链》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具