Wednesday, January 8, 2025
Google search engine
HomeLanguagesJavascriptHow to sort an array of objects by property values ?

How to sort an array of objects by property values ?

In this article, we will try to understand how to sort an array of objects by property values in JavaScript with the help of certain examples.

Pre-requisite: Array of Objects in JavaScript

Example:

Input:
[
{ name: "Ram", age: 17 },
{ name: "Mohan", age: 30 },
{ name: "Shyam", age: 15 },
{ name: "Shyam", age: 17 },
]
Output:
[
{ name: 'Shyam', age: 15 },
{ name: 'Ram', age: 17 },
{ name: 'Shyam', age: 17 },
{ name: 'Mohan', age: 30 }
]

Explanation:

  • Pick any property and sort the object on the basis of that property’s values in other objects inside an array of objects.

There are several methods that can be used to sort an array of objects by property values

  • Using sort() with compare function
  • Using sort() method
  • Using localeCompare() for string values

Approach 1: Using sort() with compare function

Here we will use the sort() method and inside the sort method, we will explicitly define a compare method for comparing values as per the user’s need. Then inside that compare() method, we will use if-else statements in order to check property values.

Example: Below is the implementation of the above approach.

Javascript




let employees_details = [
    { name: "Ram", age: 17 },
    { name: "Mohan", age: 30 },
    { name: "Shyam", age: 15 },
    { name: "Shyam", age: 17 },
];
 
let compare = (a, b) => {
    if (a.age < b.age) {
        return -1;
    }
    if (a.age > b.age) {
        return 1;
    }
    return 0;
};
 
employees_details.sort(compare);
console.log(employees_details);


Output

[
  { name: 'Shyam', age: 15 },
  { name: 'Ram', age: 17 },
  { name: 'Shyam', age: 17 },
  { name: 'Mohan', age: 30 }
]

Approach 2: Using sort() method

This approach also uses the sort() method but unlike the previous approach here we will shorten the syntax and do all the work as inline itself. In the inline technique, we will use the ternary operator concept in order to compare two different values and then return the corresponding results.

Example: Below is the implementation of the above approach.

Javascript




let employees_details = [
    { name: "Ram", age: 17 },
    { name: "Mohan", age: 30 },
    { name: "Shyam", age: 15 },
    { name: "Shyam", age: 17 },
];
 
employees_details.sort((a, b) => (
    a.age > b.age ? 1 : b.age > a.age ? -1 : 0));
console.log(employees_details);


Output

[
  { name: 'Shyam', age: 15 },
  { name: 'Ram', age: 17 },
  { name: 'Shyam', age: 17 },
  { name: 'Mohan', age: 30 }
]

Approach 3: Using localeCompare() for string values

localeCompare() compares strings in alphabetical order. Sorting objects by a string property results in an alphabetically sorted array.

Example: The employees_details array is sorted alphabetically based on the name property using localeCompare().

Javascript




let employees_details = [
    { name: "Ram", age: 17 },
    { name: "Mohan", age: 30 },
    { name: "Shyam", age: 15 },
    { name: "Shyam", age: 17 },
];
 
employees_details.sort((a, b) =>
    a.name.localeCompare(b.name));
console.log(employees_details);


Output

[
  { name: 'Mohan', age: 30 },
  { name: 'Ram', age: 17 },
  { name: 'Shyam', age: 15 },
  { name: 'Shyam', age: 17 }
]
Whether you’re preparing for your first job interview or aiming to upskill in this ever-evolving tech landscape, neveropen Courses are your key to success. We provide top-quality content at affordable prices, all geared towards accelerating your growth in a time-bound manner. Join the millions we’ve already empowered, and we’re here to do the same for you. Don’t miss out – check it out now!

RELATED ARTICLES

Most Popular

Recent Comments