JavaScript には組み込みの Set オブジェクトがありませんが、開発者は多くの場合、高速検索で順序付けされていない一意の値を保存する機能を必要とします。
ブール値を持つオブジェクトの使用:
質問で示唆されているように、オブジェクトを使用してセットを模倣することができます。キーは値を表し、値はすべて true (または null 以外の値) に設定されます。このアプローチでは検索と削除が高速に行われますが、キーの数が増えると追加が遅くなります。
ES6 Set Object:
環境が ES6 をサポートしている場合 (最新のブラウザーやトランスパイルされたものなど)コード)、組み込みの Set オブジェクトを使用できます。すべてのセット操作に対して優れたパフォーマンスを発揮し、さらに要素の繰り返しを容易にし、文字列の強制を回避できます。
ポリフィルと事前構築オブジェクト:
をサポートしていない環境の場合ES6 では、「ES6-Set」などのポリフィル、または ES6 Set オブジェクトと同様の機能を提供する「miniSet」や「set.js」などの事前構築済みオブジェクトを使用できます。これらには、古いブラウザとの互換性やコード フットプリントの縮小などの利点があります。
実装の詳細:
オブジェクトの使用:
const setObj = {};
setObj["item1"] = true;
if ("item1" in setObj) { // fast lookup
console.log("Item found");
}
delete setObj["item1"]; // fast deletion
ES6 Set オブジェクトの使用:
const set = new Set();
set.add("item1");
if (set.has("item1")) { // fast lookup
console.log("Item found");
}
set.delete("item1"); // fast deletion
Polyfill の使用:
import Set from "es6-set";
const set = new Set(["item1", "item2"]);
console.log(...set.keys()); // easy iteration
事前に構築されたオブジェクトの使用:
const miniSet = new MiniSet("item1", "item2");
if (miniSet.has("item1")) { // fast lookup
console.log("Item found");
}
miniSet.remove("item1"); // fast deletion
最適な選択は、特定の要件と環境で利用可能なサポートによって異なります。複雑なアプリケーションやパフォーマンスが重要なアプリケーションには、ES6 Set オブジェクトが最適です。それ以外の場合は、オブジェクト、ポリフィル、または事前に構築されたセット オブジェクトを使用すると、合理的な解決策が得られます。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3