單行代碼極難維護(有時甚至很難理解),但這都無法阻止它們非常酷。完成編寫一個極簡解決方案后,你一定會很滿足的。
這有一些我最近心愛的收藏。它們都可以直接在你的開放控制臺中運行,來試試吧。我希望你也可以在評論中分享你喜歡的代碼。
1. 日歷黑客
Ali Spittel 推送了 最近動態。它解決了一個我多次面對的問題。如果你把減號換成加號,它會給你接下來七天的日子。
// 創建一個過去七天的數組,包含 [...Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days));
2. 隨機生成 ID
這是我在原型化時創建唯一 ID 的常用功能。我甚至曾見有人在生產模式中使用它。這不是安全的,但是……還有更差的隨機生成函數。
// 生成一個長度為 11 的隨機字母字符串 Math.random().toString(36).substring(2);
3、Quine
quine 是一個輸出自身源碼的程序。Quine 總讓我如此癡迷。我已經有好幾次用不同的語言來完成我自己的quine了,但是細節是最重要的。
我為你挑選了一些優勝者。這三個分別來自 Mama Fun Roll, PleaseStand,和 Peter Olson 。
// $=_=>`$=${$};$()`;$() $=_=>`$=${$};$()`;$() // eval(I="'eval(I='+JSON.stringify(I)+')'") eval(I="'eval(I='+JSON.stringify(I)+')'") // For those who like their quines via alert // (function a(){alert("("+a+")()")})() (function a(){alert("("+a+")()")})()
4、獲取查詢參數
這是關于不可維護的代碼。這會把頁面的查詢參數轉換為 78 字節的對象。感謝 Alex Lohr 提供代碼實現(還有齊翊)。
?foo=bar&baz=bing => {foo: bar, baz: bing}
// 設置 `q` 的值為當前頁面的查詢參數 q={};location.search.replace(/([^?&=]+)=([^&]*)/g,(_,k,v)=>q[k]=v);q;
我想看到迷你機這么努力的工作。
5. 工作鬧鐘
僅需少量代碼,你就可以創建一個工作鬧鐘,并且你可以一口氣讀完它的源碼。經過和同事的挑戰,我寫了這篇文章。它每秒鐘計時一次,并使用當前時間更新頁面。
<body onload="setInterval(()=>document.body.innerHTML=new Date().toGMTString().slice(17,25))"></body>
6、隨機排列一個數組
在 Pythonistas 展示 import random
,random.shuffle(array)
解決方案前,我們只能自食其力。這有一個好處是,成為無限循環的機會很小(取決于你的實現)。Michiel Hendriks 幫助我們節省一些字符