I have some array of products inside filteredProducts
variable and wanted to sort them according to the price and newly added products.
When using prevState like this without having { }
in the callback function, the code runs fine.
JavaScript
x
18
18
1
useEffect(() => {
2
if(sort === "newest") {
3
setFilteredProducts((prevState) =>
4
[prevState].sort((a, b) => a.createdAt - b.createdAt)
5
);
6
}
7
else if (sort === "asc") {
8
setFilteredProducts((prevState) =>
9
[prevState].sort((a ,b) => a.price - b.price)
10
);
11
}
12
else {
13
setFilteredProducts((prevState) =>
14
[prevState].sort((a, b) => b.price - a.price)
15
);
16
}
17
}, [sort]);
18
But when using { }
for the prevState callback function like this
JavaScript
1
6
1
if(sort === "newest") {
2
setFilteredProducts((prevState) => {
3
[prevState].sort((a, b) => a.createdAt - b.createdAt)
4
});
5
}
6
, it is just throwing error in console.
Advertisement
Answer
When using the brackets you are declaring a function body, and need to return a value, i.e. the next state. Arrow functions without a function body use an implicit (vs explicit) return.
JavaScript
1
4
1
setFilteredProducts((prevState) => {
2
return [prevState].sort((a, b) => a.createdAt - b.createdAt);
3
});
4