楔子
上一篇提到了 map filter reduce,這三個是最常見的也是最常用的使用方法,為了讓「程式碼」易讀,可以改造一下長相方便讓人看的懂在做什麼,至於怎做的就交給專業的人去優化改善就好。
所以先至少讓別人看的懂自已在寫的東西優先,試想看看,如果你是看 code 的人,「看的懂」vs 「要花一點點時間去細看」這二種,哪一種比較好讀? 先做到至少菜端出來看起來想吃,至於好不好吃就再說囉。嘿嘿嘿
程式碼的味道
用個最簡單的例子,把一個數字 x3 之後再 +1,但當數字是 5時就返回原值
f(1) = 1 * 3 + 1
f(5) = 5 來寫出這個 f 但我們用不同的長相來看看
撒尿牛丸全部攪在一起
這個應該是大部份的程式羅輯,就是把資料拆開來一個一個處理。
function f(x) {
if(x !== 5) {
return 3 * x + 1
} else {
return x
}
}
點點點到天邊
這個 coding-style 就像你打開一個箱子把東西拿出來,「動作」後再放回去,依序處理。
let box = x => ({f: f => box(f(x)), x})
box(1)
.f(multi3)
.f(add1) // {f: ƒ f(), x: 4}
box(5)
.f(multi3)
.f(add1) // {f: ƒ f(), x: 6}
// 運算的 function 參考用
function multi3(x) {
if(x !== 5) {
return 3 * x
} else {
return x
}
}
function add1(x) {return x+1}
按造步驟一步一步寫
這個版本和上面的版本意思差不多,就是把資料塞進去,接下來塞一堆要處理的功能。(不過也有另一派是把資料放最後,這個以後有空再討論囉)
let box = x => f => g => f(g(x))
box(1)(multi3)(add1) // 4
box(5)(multi3)(add1) // 6
// 運算的 function 參考用
function multi3(x) {
if(x !== 5) {
return 3 * x
} else {
return x
}
}
function add1(x) {return x+1}