2分鐘編程技巧:不要在代碼中使用循環
您應該使用像map、filter和reduce這樣的函數,而不是編寫for或while循環。這是個推薦做法,因為:
循環使產生代碼副作用變得容易,而副作用就會使代碼邏輯變成意大利面條,雜亂無章。
當你試圖同時做不止一件事情時,循環會你陷入痛苦。
函數式編程可以防止代碼產生與感冒藥一樣多的副作用。它迫使你一次只做一件事,而且比循環更具可讀性。
循環,就像指針一樣,是一種簡單的編程方法。它們對于某些關鍵代碼非常有用,但我想會說,我們中很少有人在研究顯卡驅動程序。
讓我們切入正題——這里有一個JavaScript程序的比較。首先,老舊的循環版本:
- const cats = ['Antonio', 'Squid', 'Tornado', 'Avocado', 'Barnacles', 'Abroteus'];
- const stringStartsWithA = x => x[0].toLowerCase() === 'a';
- const catsWhoseNameStartsWithA = [];
- for (let i = 0; i < cats.length; i++) {
- if (stringStartsWithA(cats[i])) {
- catsWhoseNameStartsWithA.push(cats[i]);
- }
- }
- console.log(catsWhoseNameStartsWithA);
- // Output:
- // ["Antonio", "Avocado", "Abroteus"]
下面是新式的函數式編程:
- const cats = ['Antonio', 'Squid', 'Tornado', 'Avocado', 'Barnacles', 'Abroteus'];
- const stringStartsWithA = x => x[0].toLowerCase() === 'a';
- const catsWhoseNameStartsWithA = cats.filter(stringStartsWithA);
- console.log(catsWhoseNameStartsWithA);
- // Output:
- // ["Antonio", "Avocado", "Abroteus"]
當然,這是一個簡單的示例,并且很可能是一個非常適合過濾器(filter)的用例。盡管如此,我們還是把5行混亂的代碼變成了….0行?在***個示例中,我們已經使用了一行代碼來聲明數組。
這里的樂趣并沒有到此為止:我們用過濾器來做例子,但還有更多像map, reduce, sort和flatten這樣的用法。它們為我們編寫有創意,優雅,最重要的是易于理解的代碼提供了巨大的空間!
你怎么認為?也許我的例子有失偏頗,也許我完全錯了。請在評論中告訴我-我感謝任何和所有的反饋!