簡介
? 更新平臺多偶爾會漏掉,如果覺得文章還行點個
star
防走失。
⚠️⚠️⚠️ 請注意本文不是講 console 各種方法,請不要點出去。
本來想取名為 console
黑魔法,順手講一點 console
的其他方法。可是查閱資料的時候發現好多文章都已經寫得非常好了,這部分相關的內容大家可以到掘金
檢視 ? 傳送門。
今天來講點不一樣的,其實有了那麼多 console
方法開發中最經常用到的還是 console.log
,那你知道怎麼讓 console.log
來幫你摸 ? 減少 Debug 工作量嘛?
ps: 當然天下除蟲,唯斷點除錯不破。
普通 Debug
在開發時最經常碰到的場景之一就是函式巢狀了:
star(
pushmetop(
github('ok!')
)
)
複製程式碼
好傢伙這巢狀夠深,如果前方產品八米加急找到你說請求 star 函式出錯了,一臉視死如歸的同學開啟對應程式碼開始除錯:
const a = github('ok!');
console.log(a);
const b = pushmetop(a);
console.log(b);
const c = star(b);
console.log(c);
複製程式碼
超級 Debug
好傢伙滿滿當當的魔術變數和 console.log
,這顯然會減少大量摸?時間,機智的我們為何不對 console.log
進行升級:
const superme = (x) => (console.log(x), x)
複製程式碼
小技巧:利用逗號表示式來寫寫出優雅的程式碼,例如
x => (x=x+1, x)
。
這下再除蟲簡直不要太舒服,簡直指哪打哪
:
star(pushmetop(
// 想除哪就除拿
superme(github('ok!'))
))
複製程式碼
超超級 Debug
除了 iphone 有 plus 我們的 debug
怎麼可能沒有呢?
const supermePlus = (x, fn = (y) => y) => fn(x)
複製程式碼
有了 supermePlus 我們可以在除錯的時候方便的插入除錯程式碼:
star(
// 想怎麼加就怎麼加
supermePlus(pushmetop(github('ok!')), (x) => {
// 測試 x 是不是數字
console.log(typeof x === 'number' && x === x);
return x;
})
);
複製程式碼
也可以方便的替換值:
star(
supermePlus(pushmetop(github('ok!')), (x) => 'good!')
);
複製程式碼
其他
提供一個簡單的函式定義,方便大家測試本文章中的程式碼
const github = x => x;
const pushmetop = x => x + '!';
const star = x => x + '?';
複製程式碼
一起成長
如果您感覺有收穫可以點贊關注激勵我
,也歡迎到 Github 加個 star。
本文原稿來自 PushMeTop