I'm in the process of creating a one-page website to showcase COVID-19 cases in India. The base URL returns an array sorted alphabetically, but I want to sort it based on "totalConfirmed". Here's the code I have so far:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Covid19 India</title>
<!-- Bootstrap CSS 4.3.1 -->
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
<!-- Axios -->
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<!-- VueJS -->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<!-- Lodash -->
<script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/lodash.js/0.10.0/lodash.min.js"></script>
</head>
<body>
<div class="container mt-4" id="app">
<table class="table-responsive">
<table class="table">
<thead>
<tr>
<th scope="col">#</th>
<th scope="col">Location</th>
<th scope="col">Total</th>
<th scope="col">Active</th>
<th scope="col">Recovered</th>
<th scope="col">Deaths</th>
</tr>
</thead>
<tbody>
<tr v-for="state, index in states">
<th scope="row">{{ index + 1 }}</th>
<td>{{ state.loc }}</td>
<td>{{ state.totalConfirmed }}</td>
<td>{{ state.totalConfirmed - (state.discharged + state.deaths)}}</td>
<td>{{ state.discharged }}</td>
<td>{{ state.deaths }}</td>
</tr>
</tbody>
</table>
</table>
</div>
<script>
const cases = [];
var app = new Vue({
el: '#app',
data: {
states: []
},
mounted: function() {
axios.get('https://api.rootnet.in/covid19-in/stats/latest')
.then(response => {
this.states = response.data.data.regional;
this.states = cases;
cases = _.orderBy(cases, 'totalConfirmed', 'desc');
console.log(cases);
})
.catch(error => {
console.log(error);
});
}
})
</script>
</body>
</html>
I've encountered the error "TypeError: _.orderBy is not a function" in my console. What could I be doing wrong here? When I remove the orderBy function, the code runs without any errors.