Sort JavaScript map by decimal key
P粉755863750
P粉755863750 2023-09-19 14:44:41
0
1
634

I have a map with a key of month and a key value of 1... 31. If I understand correctly, JavaScript converts the map's keys to strings.

Use the standard new Map([...myMap.entries()].sort())After sorting, the map is sorted by key as follows:

1, 11, 12, 13, ..., 19, 2, 20, 21, 22, 23, ... 29, 3, 30, 31.

I found a way to convert the decimal key to a string and fill the single numbers with 0 to achieve 1,2,3,4,5, ... Sort by:

mykey.toString().padStart(2, "0");

I suspect this approach is too contrived and there should be some pre-built JavaScript method to achieve normal map sorting by the decimal value of the key.

Any suggestions on how to sort JavaScript maps by decimal key in a better way?

Triednew Map([...myMap.entries()].sort()) - The map was sorted as: 1, 11, 12, ..., 19, 2, 20 , 21, 22, ... 29, 3, 30, 31.

P粉755863750
P粉755863750

reply all(1)
P粉501683874

Although any type can be used in the key of a Map() object, they are coerced when using the default sort() implementation Convert to string.

To solve this problem, you need to implement your own sorting logic to explicitly compare them as numerical values. In the example below it uses integers, but this can be easily updated to use parseFloat() if decimal comparisons are required.

const map = new Map();
map.set(3, "foo");
map.set(1, "foo");
map.set(8, "foo");
map.set(10, "foo");
map.set(5, "foo");
map.set(2, "foo");
map.set(4, "foo");
map.set(7, "foo");
map.set(6, "foo");
map.set(9, "foo");

// does not work:
const mapFailedSort =  new Map([...map.entries()].sort());
console.log(mapFailedSort);

// works:
const mapAsc = new Map([...map.entries()].sort((a, b) => +a[0] > +b[0] ? 1 : -1));
console.log(mapAsc)

Note: The code snippet console appears to be incompatible with Map() objects - please check the output in the dev tools console to see if the ordering is correct.

Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template