現代のJSで Function コンストラクタを直接触ることはほとんどないと思いますが、隠された機能がちょっと面白いので本記事で説明します。 Function コンストラクタ JavaScriptの Function 関数は厳密にはクラスではありませんが、クラスのように使うことができます。 // typeof object === "function" とするべきだが、これでもほぼ同様に判定できる if (object instanceof Function) { // ... } // ソースコードから関数を生成 const f = new Function("x", "\"use strict\"; return x + 1"); console.log(f(42)); // => 43 // newが無くても同じ const f = Function("x", "\"use stri
![Functionのサブクラス (JavaScript)](https://cdn-ak-scissors.b.st-hatena.com/image/square/efd802bd6112f25ce1e00adcdcca23524dcf2ba1/height=288;version=1;width=512/https%3A%2F%2Fres.cloudinary.com%2Fzenn%2Fimage%2Fupload%2Fs--EHsTb-v_--%2Fc_fit%252Cg_north_west%252Cl_text%3Anotosansjp-medium.otf_55%3AFunction%2525E3%252581%2525AE%2525E3%252582%2525B5%2525E3%252583%252596%2525E3%252582%2525AF%2525E3%252583%2525A9%2525E3%252582%2525B9%252520%252528JavaScript%252529%252Cw_1010%252Cx_90%252Cy_100%2Fg_south_west%252Cl_text%3Anotosansjp-medium.otf_37%3AMasaki%252520Hara%252Cx_203%252Cy_121%2Fg_south_west%252Ch_90%252Cl_fetch%3AaHR0cHM6Ly9saDMuZ29vZ2xldXNlcmNvbnRlbnQuY29tL2EtL0FPaDE0R2l3aEI4dTM5cFZyM09sWVFLcUU5Z1ozV2d3MHlsMS03cUZad0huYWc9czI1MC1j%252Cr_max%252Cw_90%252Cx_87%252Cy_95%2Fv1627283836%2Fdefault%2Fog-base-w1200-v2.png)