如何優雅地 Debug Callback ?
栏目: JavaScript · 发布时间: 6年前
内容简介: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 到底為多少 ?
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。
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 。
確認 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 是否被執行過,我們會有疑慮。
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。
證明傳入 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() 。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
.NET设计规范
克瓦林纳 / 葛子昴 / 人民邮电出版社 / 2006-7 / 49.00元
本书为框架设计师和广大开发人员设计高质量的软件提供了权威的指南。书中介绍了在设计框架时的最佳实践,提供了自顶向下的规范,其中所描述的规范普遍适用于规模不同、可重用程度不同的框架和软件。这些规范历经.net框架三个版本的长期开发,凝聚了数千名开发人员的经验和智慧。微软的各开发组正在使用这些规范开发下一代影响世界的软件产品。. 本书适用于框架设计师以及相关的专业技术人员,也适用于高等院校相关专业......一起来看看 《.NET设计规范》 这本书的介绍吧!