JavaScript Array Sort
JavaScript Array Sort
w3schools.com LOG IN
Sorting an Array
The sort() method sorts an array alphabetically:
Example
var fruits = ["Banana", "Orange", "Apple", "Mango"];
fruits.sort(); // Sorts the elements of fruits
Try it Yourself »
Reversing an Array
The reverse() method reverses the elements in an array.
Example
https://www.w3schools.com/js/js_array_sort.asp 1/14
1/16/2021 JavaScript Array Sort
Try it Yourself »
Numeric Sort
By default, the sort() function sorts values as strings.
However, if numbers are sorted as strings, "25" is bigger than "100", because "2" is
bigger than "1".
Because of this, the sort() method will produce incorrect result when sorting numbers.
Example
Try it Yourself »
Example
var points = [40, 100, 1, 5, 25, 10];
points.sort(function(a, b){return b - a});
https://www.w3schools.com/js/js_array_sort.asp 2/14
1/16/2021 JavaScript Array Sort
Try it Yourself »
The compare function should return a negative, zero, or positive value, depending on the
arguments:
function(a, b){return a - b}
When the sort() function compares two values, it sends the values to the compare
function, and sorts the values according to the returned (negative, zero, positive) value.
If the result is 0 no changes are done with the sort order of the two values.
Example:
The compare function compares all the values in the array, two values at a time (a, b) .
https://www.w3schools.com/js/js_array_sort.asp 3/14
1/16/2021 JavaScript Array Sort
When comparing 40 and 100, the sort() method calls the compare function(40, 100).
The function calculates 40 - 100 (a - b) , and since the result is negative (-60), the
sort function will sort 40 as a value lower than 100.
You can use this code snippet to experiment with numerically and alphabetically sorting:
<p id="demo"></p>
<script>
var points = [40, 100, 1, 5, 25, 10];
document.getElementById("demo").innerHTML = points;
function myFunction1() {
points.sort();
document.getElementById("demo").innerHTML = points;
}
function myFunction2() {
points.sort(function(a, b){return a - b});
document.getElementById("demo").innerHTML = points;
}
</script>
Try it Yourself »
Example
var points = [40, 100, 1, 5, 25, 10];
points.sort(function(a, b){return 0.5 - Math.random()});
https://www.w3schools.com/js/js_array_sort.asp 4/14
1/16/2021 JavaScript Array Sort
Try it Yourself »
The most popular correct method, is called the Fisher Yates shuffle, and was introduced
in data science as early as 1938!
Example
var points = [40, 100, 1, 5, 25, 10];
Try it Yourself »
However, after you have sorted an array, you can use the index to obtain the highest
and lowest values.
Sorting ascending:
https://www.w3schools.com/js/js_array_sort.asp 5/14
1/16/2021 JavaScript Array Sort
Example
var points = [40, 100, 1, 5, 25, 10];
points.sort(function(a, b){return a - b});
// now points[0] contains the lowest value
// and points[points.length-1] contains the highest value
Try it Yourself »
Sorting descending:
Example
var points = [40, 100, 1, 5, 25, 10];
points.sort(function(a, b){return b - a});
// now points[0] contains the highest value
// and points[points.length-1] contains the lowest value
Try it Yourself »
Sorting a whole array is a very inefficient method if you only want to find the highest (or
lowest) value.
Example
https://www.w3schools.com/js/js_array_sort.asp 6/14
1/16/2021 JavaScript Array Sort
function myArrayMax(arr) {
return Math.max.apply(null, arr);
}
Try it Yourself »
Example
function myArrayMin(arr) {
return Math.min.apply(null, arr);
}
Try it Yourself »
This function loops through an array comparing each value with the highest value found:
while (len--) {
if (arr[len] > max) {
max = arr[len];
}
}
return max;
}
Try it Yourself »
This function loops through an array comparing each value with the lowest value found:
function myArrayMin(arr) {
var len = arr.length;
var min = Infinity;
while (len--) {
if (arr[len] < min) {
min = arr[len];
}
}
return min;
}
Try it Yourself »
Example
var cars = [
{type:"Volvo", year:2016},
https://www.w3schools.com/js/js_array_sort.asp 8/14
1/16/2021 JavaScript Array Sort
{type:"Saab", year:2001},
{type:"BMW", year:2010}
];
Even if objects have properties of different data types, the sort() method can be used
to sort the array.
Example
cars.sort(function(a, b){return a.year - b.year});
Try it Yourself »
Example
cars.sort(function(a, b){
var x = a.type.toLowerCase();
var y = b.type.toLowerCase();
if (x < y) {return -1;}
if (x > y) {return 1;}
return 0;
});
Try it Yourself »
https://www.w3schools.com/js/js_array_sort.asp 9/14