Vue Js Sort Array Object by Json property:To sort an array of objects in Vue.js by a JSON property, you can use the Array.prototype.sort()
method along with a custom comparison function. First, access the array of objects and pass a comparison function to the sort()
method. The comparison function should take two objects and compare the desired JSON property using dot notation, such as obj1.property
and obj2.property
. Finally, return the result of the comparison to determine the order of the objects in the sorted array.
How can I sort an array of objects in Vue js based on a JSON property?
In the provided code, a Vue.js application is created with an array of items as the data property. Each item is an object with properties such as id, name, and price. The method sortItems()
is defined to sort the items array based on the price
property using the sort()
method with a comparison function.
The computed property sortedItems()
returns the sorted array. When the application is mounted on the element with the id app
, the items will be displayed in the order of ascending prices.
Vue Js Sort Array Object by Json property
<script type="module" >
const app = Vue.createApp({
data() {
return {
items: [
{ id: 1, name: 'Apple', price: 2.5 },
{ id: 2, name: 'Orange', price: 1.8 },
{ id: 3, name: 'Banana', price: 0.9 }
]
};
},
methods: {
sortItems() {
this.items.sort((a, b) => a.price - b.price);
}
},
computed: {
sortedItems() {
return this.items;
}
}
});
app.mount('#app');
</script>