ESLint не любит операторы let внутри блоков case внутри редуктора. Почему?
Используйте {}
для создания области видимости блока с case, например:
case DELETE_INTEREST: {
let .....
return (...)
}
Проверьте этот фрагмент:
function withOutBraces() {
switch(1){
case 1:
let a=10;
console.log('case 1', a);
case 2:
console.log('case 2', a)
}
}
function withBraces() {
switch(1){
case 1: {
let a=10;
console.log('case 1', a);
}
case 2: {
console.log('case 2', a)
}
}
}
console.log('========First Case ============')
withOutBraces()
console.log('========Second Case ============')
withBraces();
Для удаления элемента из массива используйте array.filter , поскольку splice внесет изменения в исходный массив.Напишите это так:
case DELETE_INTEREST:
let deleteInterests = state.user.interests;
let newData = deleteInterests.filter(i => i !== action.payload);
return { ...state, user: { ...state.user, interests: newData } };