Table of contents
No headings in the article.
Are you familiar with JavaScript? Have you ever come across some tricks or techniques that make your work more efficient? If you haven't, then this blog post is for you. In this article, we will share 5 cool and useful JavaScript coding techniques that you should know about.
- Swapping Variables: Previously, swapping variables required a temporary variable. However, with array deconstruction, we can swap variables more easily.
let myFood = '๐'
let yourFood = '๐ซ'
[myFood, yourFood] = [yourFood, myFood]
console.log(myFood, yourFood) // ๐ซ ๐
- Avoid Pointless If Else statements: If you have a lot of conditions to check, you can use an object to hold all the data and make it faster to retrieve. This way, you can avoid writing long, complicated if statements:
const getPriceByName = (name) => {
const foodMap = {
'๐': 30,
'๐จ': 20,
'๐ฟ': 10,
// You can add new food here
// ...
}
return foodMap[name]
}
console.log(getPriceByName('๐')) // 30
- Object.entries Is a Smarter Way to Traverse If you want to iterate over an object, you can use
Object.entries()
to get an array of key-value pairs. This is better than using afor...in
loop because you can avoid iterating over properties on object prototypes:
const foodMap = {
'๐': 30,
'๐จ': 20,
'๐ฟ': 10,
'๐ซ': 5
}
// โ
for (const key in foodMap) {
console.log(key, foodMap[key])
}
// โ
Object.entries(foodMap).forEach(([key, value]) => {
console.log(key, value)
})
- Flattening an Array If you have a nested array and you want to flatten it, you can use the
flat()
method. This method creates a new array with all sub-array elements concatenated into it recursively up to the specified depth:
const foods = [['๐', ['๐ซ']], ['๐จ', ['๐ฟ', ['๐ต']]]]
console.log(foods.flat(Infinity)) // ['๐', '๐ซ', '๐จ', '๐ฟ', '๐ต']
Alternatively, you can use the reduce() method to flatten an array. For example:
const flattenFoods = (foods) => { return foods.reduce((res, food) => {
return res.concat(Array.isArray(food) ? flattenFoods(food) : food); }, []); };
console.log(flattenFoods(foods)); // ['๐', '๐ซ', '๐จ', '๐ฟ', '๐ต']
- Calculate the Total Price of the Goods If you need to calculate the total price of an array of objects, you can use the
reduce()
method to simplify your code:
const foods = [
{
name: '๐',
price: 30,
amount: 10,
},
{
name: '๐จ',
price: 20,
amount: 3,
},
{
name: '๐ฟ',
price: 10,
amount: 5,
},
{
name: '๐ต',
price: 5,
amount: 9,
},
]
const sum = foods.reduce((total, food) => total + food.price * food.amount, 0)
console.log(sum) // 455
By incorporating these techniques into your coding, you can significantly improve your productivity and the efficiency of your code.
ย