{"id":87073,"date":"2024-12-06T17:46:43","date_gmt":"2024-12-06T14:16:43","guid":{"rendered":"https:\/\/nabfollower.com\/blog\/a-slightly-better-map-can-get-you-there-more-easily-3h6j\/"},"modified":"2024-12-06T17:46:43","modified_gmt":"2024-12-06T14:16:43","slug":"a-slightly-better-map-can-get-you-there-more-easily-3h6j","status":"publish","type":"post","link":"https:\/\/nabfollower.com\/blog\/a-slightly-better-map-can-get-you-there-more-easily-3h6j\/","title":{"rendered":"\u06cc\u06a9 \u00ab\u0646\u0642\u0634\u0647\u00bb \u06a9\u0645\u06cc \u0628\u0647\u062a\u0631\u060c \u062e\u0648\u0627\u0646\u062f\u0646 \u06a9\u062f \u0634\u0645\u0627 \u0631\u0627 \u0622\u0633\u0627\u0646\u200c\u062a\u0631 \u0645\u06cc\u200c\u06a9\u0646\u062f&#8230;"},"content":{"rendered":"<p>Summarize this content to 400 words in Persian Lang<br \/>\n              \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u060c Map \u06cc\u06a9 \u06a9\u0644\u0627\u0633 \u062f\u0627\u062e\u0644\u06cc \u0628\u0633\u06cc\u0627\u0631 \u0645\u0641\u06cc\u062f \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u062c\u0633\u062a\u062c\u0648\u06cc O(1) \u0628\u06cc\u0646 \u06cc\u06a9 \u06a9\u0644\u06cc\u062f \u0648 \u06cc\u06a9 \u0645\u0642\u062f\u0627\u0631 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>const myMap = new Map()<\/p>\n<p>for(const file of files) {<br \/>\n    const [,extension] = file.name.split(&#8220;.&#8221;)<br \/>\n    if(!myMap.has(extension)) {<br \/>\n        myMap.set(extension, [])<br \/>\n    }<br \/>\n    myMap.get(extension).push(file)<br \/>\n}<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 Maps \u0628\u0631\u0627\u06cc \u0627\u0646\u0648\u0627\u0639 \u06a9\u0627\u0631\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u062d\u062a\u0645\u0627\u0644\u0627\u064b \u0645\u0631\u062a\u0628\u0627\u064b \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u062f\u0647\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<p>\u0627\u06cc\u062c\u0627\u062f \u0644\u06cc\u0633\u062a \u0647\u0627\u06cc \u06af\u0631\u0648\u0647 \u0628\u0646\u062f\u06cc \u0634\u062f\u0647 \u0627\u0632 \u062f\u0627\u062f\u0647 \u0647\u0627\u060c \u0645\u0627\u0646\u0646\u062f \u0645\u062b\u0627\u0644 \u0628\u0627\u0644\u0627 \u06af\u0631\u0648\u0647 \u0628\u0646\u062f\u06cc \u0628\u0631 \u0627\u0633\u0627\u0633 \u067e\u0633\u0648\u0646\u062f \u0641\u0627\u06cc\u0644<br \/>\n\u062c\u0645\u0639\u200c\u0622\u0648\u0631\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u060c \u0645\u0627\u0646\u0646\u062f \u0634\u0645\u0627\u0631\u0634 \u06cc\u0627 \u062c\u0645\u0639 \u06a9\u0631\u062f\u0646 \u0645\u0642\u0627\u062f\u06cc\u0631 \u062f\u0631 \u0637\u06cc\u0641\u06cc \u0627\u0632 \u06a9\u0644\u06cc\u062f\u0647\u0627<\/p>\n<p>const items = [&#8216;apple&#8217;,&#8217;apple&#8217;,&#8217;orange&#8217;,&#8217;banana&#8217;,&#8217;apple&#8217;];<br \/>\nconst counts = new Map();<br \/>\nfor (const item of items) {<br \/>\n  counts.set(item, (counts.get(item) || 0) + 1);<br \/>\n}<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0627\u06cc\u062c\u0627\u062f \u062c\u0633\u062a\u062c\u0648\u0647\u0627\u06cc \u0633\u0631\u06cc\u0639 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062f\u0631 \u0645\u0631\u0627\u062d\u0644 \u0628\u0639\u062f\u06cc<\/p>\n<p>const users = [<br \/>\n  {id:1,name:&#8217;A&#8217;,role:&#8217;admin&#8217;},<br \/>\n  {id:2,name:&#8217;B&#8217;,role:&#8217;user&#8217;},<br \/>\n  {id:3,name:&#8217;C&#8217;,role:&#8217;user&#8217;}<br \/>\n];<br \/>\nconst userMap = new Map();<br \/>\nfor (const u of users) {<br \/>\n  userMap.set(u.id, u);<br \/>\n}<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0646\u0642\u0634\u0647 \u0628\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0634\u06cc \u0633\u0627\u062f\u0647 \u062a\u0631\u062c\u06cc\u062d \u062f\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f ({}) \u0628\u0647 \u0686\u0646\u062f \u062f\u0644\u06cc\u0644\u060c \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0645\u062c\u0628\u0648\u0631 \u0646\u0628\u0627\u0634\u06cc\u062f \u0646\u062a\u06cc\u062c\u0647 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 a \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f stringify:<\/p>\n<p>\u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u06af\u06cc\u0631\u062f \u06a9\u0647 \u0631\u0634\u062a\u0647 \u0627\u06cc \u0646\u06cc\u0633\u062a\u0646\u062f<br \/>\n\u062d\u062a\u06cc \u0627\u06af\u0631 \u0627\u0632 \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc \u0631\u0634\u062a\u0647 \u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0645\u06cc \u0633\u0631\u06cc\u0639\u062a\u0631 \u0627\u0632 \u06cc\u06a9 \u0634\u06cc\u0621 \u0627\u0633\u062a<\/p>\n<p>\u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0646\u06af\u0631\u0627\u0646\u06cc\u200c\u0647\u0627\u06cc \u0632\u06cc\u0627\u062f\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0627\u0645\u0627 \u0627\u06af\u0631 \u0634\u06cc\u0626\u06cc \u06a9\u0647 \u062f\u0631 \u0646\u0642\u0634\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0633\u0627\u062e\u062a \u062f\u0627\u0631\u062f\u060c \u06a9\u0647 \u0627\u0632 \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u0633\u0627\u062f\u0647 \u06af\u0631\u0641\u062a\u0647 \u062a\u0627 \u06cc\u06a9 \u0634\u06cc \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0627\u0633\u062a\u060c \u0627\u06cc\u0646 \u0628\u0627\u06cc\u062f \u0628\u0627 \u06a9\u062f\u06cc \u06a9\u0647 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f\u060c \u0622\u0645\u06cc\u062e\u062a\u0647 \u0634\u0648\u062f.<\/p>\n<p>const map = new Map()<\/p>\n<p>for(const item of items) {<br \/>\n   if(!map.has(item.type)) {<br \/>\n       const newType = new Type(item.type, getInfoForType(item.type))<br \/>\n       map.set(item.type, newType)<br \/>\n   }<br \/>\n   map.get(item.type).doSomething(item)<\/p>\n<p>}<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0627\u06cc\u0646 &#8220;\u0645\u06cc \u062a\u0648\u0627\u0646\u062f&#8221; \u062e\u0648\u0628 \u0627\u0633\u062a\u060c \u0627\u0645\u0627 \u0627\u06af\u0631 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u06cc\u0627 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u062f\u0631 \u0686\u0646\u062f\u06cc\u0646 \u0645\u06a9\u0627\u0646 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f\u060c \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0646 DRY \u062f\u0634\u0648\u0627\u0631\u062a\u0631 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0645\u0646 \u0627\u0632 \u06cc\u06a9 \u06a9\u0644\u0627\u0633 MapPlus \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0645\u060c \u06a9\u0647 \u067e\u0633\u0648\u0646\u062f\u06cc \u0628\u0631\u0627\u06cc Map \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u0627\u0648\u0644\u06cc\u0647 \u06a9\u0644\u06cc\u062f \u06af\u0645 \u0634\u062f\u0647 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0647 \u0633\u0627\u0632\u0646\u062f\u0647 \u06cc\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u062f\u0648\u0645 \u0628\u0631\u0627\u06cc get \u0627\u06af\u0631 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0628\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0632\u0645\u06cc\u0646\u0647 \u0641\u0631\u0627\u062a\u0631 \u0627\u0632 \u06a9\u0644\u06cc\u062f \u0646\u06cc\u0627\u0632 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.<\/p>\n<p>class MapPlus extends Map {<br \/>\n    constructor(missingFunction) {<br \/>\n        super()<br \/>\n        this.missingFunction = missingFunction<br \/>\n    }<\/p>\n<p>    get(key, createIfMissing = this.missingFunction) {<br \/>\n        let result = super.get(key)<br \/>\n        if (!result &amp;&amp; createIfMissing) {<br \/>\n            result = createIfMissing(key)<br \/>\n            if (result &amp;&amp; result.then) {<br \/>\n                const promise = result.then((value) =&gt; {<br \/>\n                    super.set(key, value)<br \/>\n                    return value<br \/>\n                })<br \/>\n                super.set(key, promise)<br \/>\n            } else {<br \/>\n                super.set(key, result)<br \/>\n            }<br \/>\n        }<br \/>\n        return result<br \/>\n    }<br \/>\n}<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0641\u0642\u0637 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06a9\u0627\u0631\u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f:<\/p>\n<p>const map = new MapPlus(()=&gt;[])<\/p>\n<p>for(const item of items) {<br \/>\n    map.get(item.type).push(item)<br \/>\n}<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u0627\u06af\u0631 \u06a9\u0644\u06cc\u062f \u0627\u0632 \u062f\u0633\u062a \u0631\u0641\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0641\u0642\u0637 \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u062e\u0627\u0644\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f\u060c \u0627\u0645\u0627 \u062e\u0648\u062f \u062d\u0644\u0642\u0647 \u0633\u0627\u062f\u0647 \u0648 \u062a\u0645\u06cc\u0632 \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0647 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0641\u0642\u0637 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u0644\u06cc\u0633\u062a \u0645\u0631\u0628\u0648\u0637 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0645\u0646 \u0627\u063a\u0644\u0628 \u0628\u0647 \u062f\u0648 \u0633\u0637\u062d \u0627\u0632 \u0627\u06cc\u0646 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u0645\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0646\u0642\u0634\u0647 \u0647\u0627 \u0631\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u0645:<\/p>\n<p>const map = new MapPlus(()=&gt;new MapPlus(()=&gt;[]))<br \/>\nfor(const item of items) {<br \/>\n   map.get(item.type).get(item.subType).push(item)<br \/>\n}<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<p>\u062a\u0627\u0628\u0639 \u0633\u0627\u0632\u0646\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f key \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645:<\/p>\n<p>const map = new MapPlus((type)=&gt;new Type(type, getInfoForType(type))<\/p>\n<p>for(const item of items) {<br \/>\n    map.get(item.type).doSomething(item)<br \/>\n}<\/p>\n<p>    \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/p>\n<p>    \u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/p>\n<div data-article-id=\"2140850\" id=\"article-body\">\n<p>\u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u060c <code>Map<\/code> \u06cc\u06a9 \u06a9\u0644\u0627\u0633 \u062f\u0627\u062e\u0644\u06cc \u0628\u0633\u06cc\u0627\u0631 \u0645\u0641\u06cc\u062f \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u062c\u0633\u062a\u062c\u0648\u06cc O(1) \u0628\u06cc\u0646 \u06cc\u06a9 \u06a9\u0644\u06cc\u062f \u0648 \u06cc\u06a9 \u0645\u0642\u062f\u0627\u0631 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight javascript\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">myMap<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Map<\/span><span class=\"p\">()<\/span>\n\n<span class=\"k\">for<\/span><span class=\"p\">(<\/span><span class=\"kd\">const<\/span> <span class=\"nx\">file<\/span> <span class=\"k\">of<\/span> <span class=\"nx\">files<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n    <span class=\"kd\">const<\/span> <span class=\"p\">[,<\/span><span class=\"nx\">extension<\/span><span class=\"p\">]<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">file<\/span><span class=\"p\">.<\/span><span class=\"nx\">name<\/span><span class=\"p\">.<\/span><span class=\"nf\">split<\/span><span class=\"p\">(<\/span><span class=\"dl\">\"<\/span><span class=\"s2\">.<\/span><span class=\"dl\">\"<\/span><span class=\"p\">)<\/span>\n    <span class=\"k\">if<\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">myMap<\/span><span class=\"p\">.<\/span><span class=\"nf\">has<\/span><span class=\"p\">(<\/span><span class=\"nx\">extension<\/span><span class=\"p\">))<\/span> <span class=\"p\">{<\/span>\n        <span class=\"nx\">myMap<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">extension<\/span><span class=\"p\">,<\/span> <span class=\"p\">[])<\/span>\n    <span class=\"p\">}<\/span>\n    <span class=\"nx\">myMap<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"nx\">extension<\/span><span class=\"p\">).<\/span><span class=\"nf\">push<\/span><span class=\"p\">(<\/span><span class=\"nx\">file<\/span><span class=\"p\">)<\/span>\n<span class=\"p\">}<\/span>\n\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 Maps \u0628\u0631\u0627\u06cc \u0627\u0646\u0648\u0627\u0639 \u06a9\u0627\u0631\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u062d\u062a\u0645\u0627\u0644\u0627\u064b \u0645\u0631\u062a\u0628\u0627\u064b \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u062f\u0647\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<ul>\n<li>\n<p>\u0627\u06cc\u062c\u0627\u062f \u0644\u06cc\u0633\u062a \u0647\u0627\u06cc \u06af\u0631\u0648\u0647 \u0628\u0646\u062f\u06cc \u0634\u062f\u0647 \u0627\u0632 \u062f\u0627\u062f\u0647 \u0647\u0627\u060c \u0645\u0627\u0646\u0646\u062f \u0645\u062b\u0627\u0644 \u0628\u0627\u0644\u0627 \u06af\u0631\u0648\u0647 \u0628\u0646\u062f\u06cc \u0628\u0631 \u0627\u0633\u0627\u0633 \u067e\u0633\u0648\u0646\u062f \u0641\u0627\u06cc\u0644<\/p>\n<\/li>\n<li>\n<p>\u062c\u0645\u0639\u200c\u0622\u0648\u0631\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u060c \u0645\u0627\u0646\u0646\u062f \u0634\u0645\u0627\u0631\u0634 \u06cc\u0627 \u062c\u0645\u0639 \u06a9\u0631\u062f\u0646 \u0645\u0642\u0627\u062f\u06cc\u0631 \u062f\u0631 \u0637\u06cc\u0641\u06cc \u0627\u0632 \u06a9\u0644\u06cc\u062f\u0647\u0627<\/p>\n<\/li>\n<\/ul>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight javascript\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">items<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span><span class=\"dl\">'<\/span><span class=\"s1\">apple<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span><span class=\"dl\">'<\/span><span class=\"s1\">apple<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span><span class=\"dl\">'<\/span><span class=\"s1\">orange<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span><span class=\"dl\">'<\/span><span class=\"s1\">banana<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span><span class=\"dl\">'<\/span><span class=\"s1\">apple<\/span><span class=\"dl\">'<\/span><span class=\"p\">];<\/span>\n<span class=\"kd\">const<\/span> <span class=\"nx\">counts<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Map<\/span><span class=\"p\">();<\/span>\n<span class=\"k\">for <\/span><span class=\"p\">(<\/span><span class=\"kd\">const<\/span> <span class=\"nx\">item<\/span> <span class=\"k\">of<\/span> <span class=\"nx\">items<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n  <span class=\"nx\">counts<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">,<\/span> <span class=\"p\">(<\/span><span class=\"nx\">counts<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">)<\/span> <span class=\"o\">||<\/span> <span class=\"mi\">0<\/span><span class=\"p\">)<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">1<\/span><span class=\"p\">);<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<ul>\n<li>\u0627\u06cc\u062c\u0627\u062f \u062c\u0633\u062a\u062c\u0648\u0647\u0627\u06cc \u0633\u0631\u06cc\u0639 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062f\u0631 \u0645\u0631\u0627\u062d\u0644 \u0628\u0639\u062f\u06cc\n<\/li>\n<\/ul>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight javascript\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">users<\/span> <span class=\"o\">=<\/span> <span class=\"p\">[<\/span>\n  <span class=\"p\">{<\/span><span class=\"na\">id<\/span><span class=\"p\">:<\/span><span class=\"mi\">1<\/span><span class=\"p\">,<\/span><span class=\"na\">name<\/span><span class=\"p\">:<\/span><span class=\"dl\">'<\/span><span class=\"s1\">A<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span><span class=\"na\">role<\/span><span class=\"p\">:<\/span><span class=\"dl\">'<\/span><span class=\"s1\">admin<\/span><span class=\"dl\">'<\/span><span class=\"p\">},<\/span>\n  <span class=\"p\">{<\/span><span class=\"na\">id<\/span><span class=\"p\">:<\/span><span class=\"mi\">2<\/span><span class=\"p\">,<\/span><span class=\"na\">name<\/span><span class=\"p\">:<\/span><span class=\"dl\">'<\/span><span class=\"s1\">B<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span><span class=\"na\">role<\/span><span class=\"p\">:<\/span><span class=\"dl\">'<\/span><span class=\"s1\">user<\/span><span class=\"dl\">'<\/span><span class=\"p\">},<\/span>\n  <span class=\"p\">{<\/span><span class=\"na\">id<\/span><span class=\"p\">:<\/span><span class=\"mi\">3<\/span><span class=\"p\">,<\/span><span class=\"na\">name<\/span><span class=\"p\">:<\/span><span class=\"dl\">'<\/span><span class=\"s1\">C<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span><span class=\"na\">role<\/span><span class=\"p\">:<\/span><span class=\"dl\">'<\/span><span class=\"s1\">user<\/span><span class=\"dl\">'<\/span><span class=\"p\">}<\/span>\n<span class=\"p\">];<\/span>\n<span class=\"kd\">const<\/span> <span class=\"nx\">userMap<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Map<\/span><span class=\"p\">();<\/span>\n<span class=\"k\">for <\/span><span class=\"p\">(<\/span><span class=\"kd\">const<\/span> <span class=\"nx\">u<\/span> <span class=\"k\">of<\/span> <span class=\"nx\">users<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n  <span class=\"nx\">userMap<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">u<\/span><span class=\"p\">.<\/span><span class=\"nx\">id<\/span><span class=\"p\">,<\/span> <span class=\"nx\">u<\/span><span class=\"p\">);<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0646\u0642\u0634\u0647 \u0628\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0634\u06cc \u0633\u0627\u062f\u0647 \u062a\u0631\u062c\u06cc\u062d \u062f\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f (<code>{}<\/code>) \u0628\u0647 \u0686\u0646\u062f \u062f\u0644\u06cc\u0644\u060c \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0645\u062c\u0628\u0648\u0631 \u0646\u0628\u0627\u0634\u06cc\u062f \u0646\u062a\u06cc\u062c\u0647 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 a \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f <code>stringify<\/code>:<\/p>\n<ul>\n<li>\u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u06af\u06cc\u0631\u062f \u06a9\u0647 \u0631\u0634\u062a\u0647 \u0627\u06cc \u0646\u06cc\u0633\u062a\u0646\u062f<\/li>\n<li>\u062d\u062a\u06cc \u0627\u06af\u0631 \u0627\u0632 \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc \u0631\u0634\u062a\u0647 \u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0645\u06cc \u0633\u0631\u06cc\u0639\u062a\u0631 \u0627\u0632 \u06cc\u06a9 \u0634\u06cc\u0621 \u0627\u0633\u062a<\/li>\n<\/ul>\n<p>\u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0646\u06af\u0631\u0627\u0646\u06cc\u200c\u0647\u0627\u06cc \u0632\u06cc\u0627\u062f\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0627\u0645\u0627 \u0627\u06af\u0631 \u0634\u06cc\u0626\u06cc \u06a9\u0647 \u062f\u0631 \u0646\u0642\u0634\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0633\u0627\u062e\u062a \u062f\u0627\u0631\u062f\u060c \u06a9\u0647 \u0627\u0632 \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u0633\u0627\u062f\u0647 \u06af\u0631\u0641\u062a\u0647 \u062a\u0627 \u06cc\u06a9 \u0634\u06cc \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0627\u0633\u062a\u060c \u0627\u06cc\u0646 \u0628\u0627\u06cc\u062f \u0628\u0627 \u06a9\u062f\u06cc \u06a9\u0647 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f\u060c \u0622\u0645\u06cc\u062e\u062a\u0647 \u0634\u0648\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight javascript\"><code>\n<span class=\"kd\">const<\/span> <span class=\"nx\">map<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Map<\/span><span class=\"p\">()<\/span>\n\n<span class=\"k\">for<\/span><span class=\"p\">(<\/span><span class=\"kd\">const<\/span> <span class=\"nx\">item<\/span> <span class=\"k\">of<\/span> <span class=\"nx\">items<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n   <span class=\"k\">if<\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">map<\/span><span class=\"p\">.<\/span><span class=\"nf\">has<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">type<\/span><span class=\"p\">))<\/span> <span class=\"p\">{<\/span>\n       <span class=\"kd\">const<\/span> <span class=\"nx\">newType<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">Type<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">type<\/span><span class=\"p\">,<\/span> <span class=\"nf\">getInfoForType<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">type<\/span><span class=\"p\">))<\/span>\n       <span class=\"nx\">map<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">type<\/span><span class=\"p\">,<\/span> <span class=\"nx\">newType<\/span><span class=\"p\">)<\/span>\n   <span class=\"p\">}<\/span>\n   <span class=\"nx\">map<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">type<\/span><span class=\"p\">).<\/span><span class=\"nf\">doSomething<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">)<\/span>\n\n<span class=\"p\">}<\/span>\n\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0627\u06cc\u0646 &#8220;\u0645\u06cc \u062a\u0648\u0627\u0646\u062f&#8221; \u062e\u0648\u0628 \u0627\u0633\u062a\u060c \u0627\u0645\u0627 \u0627\u06af\u0631 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u06cc\u0627 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u062f\u0631 \u0686\u0646\u062f\u06cc\u0646 \u0645\u06a9\u0627\u0646 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f\u060c \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0646 DRY \u062f\u0634\u0648\u0627\u0631\u062a\u0631 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0645\u0646 \u0627\u0632 \u06cc\u06a9 \u06a9\u0644\u0627\u0633 MapPlus \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0645\u060c \u06a9\u0647 \u067e\u0633\u0648\u0646\u062f\u06cc \u0628\u0631\u0627\u06cc Map \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u0627\u0648\u0644\u06cc\u0647 \u06a9\u0644\u06cc\u062f \u06af\u0645 \u0634\u062f\u0647 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0647 \u0633\u0627\u0632\u0646\u062f\u0647 \u06cc\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u062f\u0648\u0645 \u0628\u0631\u0627\u06cc <code>get<\/code> \u0627\u06af\u0631 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0628\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0632\u0645\u06cc\u0646\u0647 \u0641\u0631\u0627\u062a\u0631 \u0627\u0632 \u06a9\u0644\u06cc\u062f \u0646\u06cc\u0627\u0632 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight javascript\"><code><span class=\"kd\">class<\/span> <span class=\"nc\">MapPlus<\/span> <span class=\"kd\">extends<\/span> <span class=\"nc\">Map<\/span> <span class=\"p\">{<\/span>\n    <span class=\"nf\">constructor<\/span><span class=\"p\">(<\/span><span class=\"nx\">missingFunction<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n        <span class=\"k\">super<\/span><span class=\"p\">()<\/span>\n        <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">missingFunction<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">missingFunction<\/span>\n    <span class=\"p\">}<\/span>\n\n    <span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"nx\">key<\/span><span class=\"p\">,<\/span> <span class=\"nx\">createIfMissing<\/span> <span class=\"o\">=<\/span> <span class=\"k\">this<\/span><span class=\"p\">.<\/span><span class=\"nx\">missingFunction<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n        <span class=\"kd\">let<\/span> <span class=\"nx\">result<\/span> <span class=\"o\">=<\/span> <span class=\"k\">super<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"nx\">key<\/span><span class=\"p\">)<\/span>\n        <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"o\">!<\/span><span class=\"nx\">result<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"nx\">createIfMissing<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n            <span class=\"nx\">result<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">createIfMissing<\/span><span class=\"p\">(<\/span><span class=\"nx\">key<\/span><span class=\"p\">)<\/span>\n            <span class=\"k\">if <\/span><span class=\"p\">(<\/span><span class=\"nx\">result<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"nx\">result<\/span><span class=\"p\">.<\/span><span class=\"nx\">then<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n                <span class=\"kd\">const<\/span> <span class=\"nx\">promise<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">result<\/span><span class=\"p\">.<\/span><span class=\"nf\">then<\/span><span class=\"p\">((<\/span><span class=\"nx\">value<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\n                    <span class=\"k\">super<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">key<\/span><span class=\"p\">,<\/span> <span class=\"nx\">value<\/span><span class=\"p\">)<\/span>\n                    <span class=\"k\">return<\/span> <span class=\"nx\">value<\/span>\n                <span class=\"p\">})<\/span>\n                <span class=\"k\">super<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">key<\/span><span class=\"p\">,<\/span> <span class=\"nx\">promise<\/span><span class=\"p\">)<\/span>\n            <span class=\"p\">}<\/span> <span class=\"k\">else<\/span> <span class=\"p\">{<\/span>\n                <span class=\"k\">super<\/span><span class=\"p\">.<\/span><span class=\"nf\">set<\/span><span class=\"p\">(<\/span><span class=\"nx\">key<\/span><span class=\"p\">,<\/span> <span class=\"nx\">result<\/span><span class=\"p\">)<\/span>\n            <span class=\"p\">}<\/span>\n        <span class=\"p\">}<\/span>\n        <span class=\"k\">return<\/span> <span class=\"nx\">result<\/span>\n    <span class=\"p\">}<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0641\u0642\u0637 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06a9\u0627\u0631\u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight javascript\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">map<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">MapPlus<\/span><span class=\"p\">(()<\/span><span class=\"o\">=&gt;<\/span><span class=\"p\">[])<\/span>\n\n<span class=\"k\">for<\/span><span class=\"p\">(<\/span><span class=\"kd\">const<\/span> <span class=\"nx\">item<\/span> <span class=\"k\">of<\/span> <span class=\"nx\">items<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n    <span class=\"nx\">map<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">type<\/span><span class=\"p\">).<\/span><span class=\"nf\">push<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">)<\/span>\n<span class=\"p\">}<\/span>\n\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u0627\u06af\u0631 \u06a9\u0644\u06cc\u062f \u0627\u0632 \u062f\u0633\u062a \u0631\u0641\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0641\u0642\u0637 \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u062e\u0627\u0644\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f\u060c \u0627\u0645\u0627 \u062e\u0648\u062f \u062d\u0644\u0642\u0647 \u0633\u0627\u062f\u0647 \u0648 \u062a\u0645\u06cc\u0632 \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0647 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0641\u0642\u0637 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u0644\u06cc\u0633\u062a \u0645\u0631\u0628\u0648\u0637 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0645\u0646 \u0627\u063a\u0644\u0628 \u0628\u0647 \u062f\u0648 \u0633\u0637\u062d \u0627\u0632 \u0627\u06cc\u0646 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u0645\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0646\u0642\u0634\u0647 \u0647\u0627 \u0631\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u0645:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight javascript\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">map<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">MapPlus<\/span><span class=\"p\">(()<\/span><span class=\"o\">=&gt;<\/span><span class=\"k\">new<\/span> <span class=\"nc\">MapPlus<\/span><span class=\"p\">(()<\/span><span class=\"o\">=&gt;<\/span><span class=\"p\">[]))<\/span>\n<span class=\"k\">for<\/span><span class=\"p\">(<\/span><span class=\"kd\">const<\/span> <span class=\"nx\">item<\/span> <span class=\"k\">of<\/span> <span class=\"nx\">items<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n   <span class=\"nx\">map<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">type<\/span><span class=\"p\">).<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">subType<\/span><span class=\"p\">).<\/span><span class=\"nf\">push<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">)<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p>\u062a\u0627\u0628\u0639 \u0633\u0627\u0632\u0646\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <code>key<\/code> \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645:<\/p>\n<div class=\"highlight js-code-highlight\">\n<pre class=\"highlight javascript\"><code><span class=\"kd\">const<\/span> <span class=\"nx\">map<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">MapPlus<\/span><span class=\"p\">((<\/span><span class=\"nx\">type<\/span><span class=\"p\">)<\/span><span class=\"o\">=&gt;<\/span><span class=\"k\">new<\/span> <span class=\"nc\">Type<\/span><span class=\"p\">(<\/span><span class=\"nx\">type<\/span><span class=\"p\">,<\/span> <span class=\"nf\">getInfoForType<\/span><span class=\"p\">(<\/span><span class=\"nx\">type<\/span><span class=\"p\">))<\/span>\n\n<span class=\"k\">for<\/span><span class=\"p\">(<\/span><span class=\"kd\">const<\/span> <span class=\"nx\">item<\/span> <span class=\"k\">of<\/span> <span class=\"nx\">items<\/span><span class=\"p\">)<\/span> <span class=\"p\">{<\/span>\n    <span class=\"nx\">map<\/span><span class=\"p\">.<\/span><span class=\"nf\">get<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">type<\/span><span class=\"p\">).<\/span><span class=\"nf\">doSomething<\/span><span class=\"p\">(<\/span><span class=\"nx\">item<\/span><span class=\"p\">)<\/span>\n<span class=\"p\">}<\/span>\n<\/code><\/pre>\n<div class=\"highlight__panel js-actions-panel\">\n<div class=\"highlight__panel-action js-fullscreen-code-action\">\n    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-on\"><title>\u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M16 3h6v6h-2V5h-4V3zM2 3h6v2H4v4H2V3zm18 16v-4h2v6h-6v-2h4zM4 19h4v2H2v-6h2v4z\"\/>\n<\/svg><\/p>\n<p>    <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"20px\" height=\"20px\" viewbox=\"0 0 24 24\" class=\"highlight-action crayons-icon highlight-action--fullscreen-off\"><title>\u0627\u0632 \u062d\u0627\u0644\u062a \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0647 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f<\/title>\n    <path d=\"M18 7h4v2h-6V3h2v4zM8 9H2V7h4V3h2v6zm10 8v4h-2v-6h6v2h-4zM8 15v6H6v-4H2v-2h6z\"\/>\n<\/svg><\/p>\n<\/div>\n<\/div>\n<\/div>\n<p><iframe src=\"https:\/\/codesandbox.io\/embed\/n4dpo?initialpath=\/o6iNrRzkkY0WQ8jgwKUJ9\/embed&amp;runonclick=0\" style=\"width:100%; height:calc(300px + 8vw); border:0; border-radius: 4px; overflow:hidden;\" allow=\"geolocation; microphone; camera; midi; vr; accelerometer; gyroscope; payment; ambient-light-sensor; encrypted-media; usb\" loading=\"lazy\" sandbox=\"allow-modals allow-forms allow-popups allow-scripts allow-same-origin\"><br \/>\n<\/iframe>\n<\/p>\n<\/p><\/div>\n","protected":false},"excerpt":{"rendered":"<p>Summarize this content to 400 words in Persian Lang \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u060c Map \u06cc\u06a9 \u06a9\u0644\u0627\u0633 \u062f\u0627\u062e\u0644\u06cc \u0628\u0633\u06cc\u0627\u0631 \u0645\u0641\u06cc\u062f \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u062c\u0633\u062a\u062c\u0648\u06cc O(1) \u0628\u06cc\u0646 \u06cc\u06a9 \u06a9\u0644\u06cc\u062f \u0648 \u06cc\u06a9 \u0645\u0642\u062f\u0627\u0631 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f. const myMap = new Map() for(const file of files) { const [,extension] = file.name.split(&#8220;.&#8221;) if(!myMap.has(extension)) { myMap.set(extension, []) } myMap.get(extension).push(file) } \u0648\u0627\u0631\u062f \u062d\u0627\u0644\u062a &hellip;<\/p>\n","protected":false},"author":2,"featured_media":87074,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"fifu_image_url":"","fifu_image_alt":"","footnotes":""},"categories":[339],"tags":[],"class_list":["post-87073","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-dev"],"_links":{"self":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/87073","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/comments?post=87073"}],"version-history":[{"count":0,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/posts\/87073\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media\/87074"}],"wp:attachment":[{"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/media?parent=87073"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/categories?post=87073"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nabfollower.com\/blog\/wp-json\/wp\/v2\/tags?post=87073"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}