I have a form where a user enters their address. This then checks their address against several destinations in the UK to see which city is their nearest.
I want each destination to have different prices, for example London, UK = 50, Birmingham, UK = 200 etc.
I have written a pretty rudimentary if statement which checks the city that is returned and calculates the price. However, I’m wondering if there is a neater solution to this as it feels a bit obtuse:
if(closestCities[0].cityName == "Coventry, UK") {
travelExpenses = 10;
} else if (closestCities[0].cityName == "London, UK"){
travelExpenses = 50;
} else if (closestCities[0].cityName == "Margate, UK"){
travelExpenses = 100;
} else if (closestCities[0].cityName == "Bristol, UK"){
travelExpenses = 20;
} else if (closestCities[0].cityName == "Tamworth, UK"){
travelExpenses = 15;
} else if (closestCities[0].cityName == "Birmingham, UK"){
travelExpenses = 200;
} else {
travelExpenses = 30;
}
Advertisement
Answer
Why don’t you create an object:
let map = {
"Margate, UK": 100,
"Bristol, UK": 20 // etc.
}
It seems you also want a default value. I think in your case you could utilize the nullish coalescing operator:
The nullish coalescing operator (??) is a logical operator that returns its right-hand side operand when its left-hand side operand is null or undefined, and otherwise returns its left-hand side operand
travelExpenses = map[closestCities[0].cityName] ?? 30;