#javascript #arrays #reactjs #database
Вопрос:
Я столкнулся с проблемой, связанной с исправлением ошибки.
Я получаю данные из базы данных. данные ( объект ) содержат массив имен. У меня есть крючок useState, который содержит массив объектов. Значение-это имена. Я хочу удалить каждый объект из крючка useState, который содержит имя из массива, полученного для базы данных.
Опыт:
response.data.players = ["player1", "player2"]
const [names, setNames] = useState([
{value: "player1", label: "player1"},
{value: "player3", label: "player3"},
{value: "player2", label: "player2"},
{value: "player5", label: "player5"},
])
Я хочу, чтобы имена стали такими:
[
{value: "player3", label: "player3"},
{value: "player5", label: "player5"},
]
с минимальной временной сложностью ( я уже использую .map для обслуживания других крючков с именами, если я смогу его использовать, он идеально подойдет для временной сложности )
Спасибо
Комментарии:
1. ошибка или оптимизация кода с минимальной временной сложностью? в чем заключается содержание
.map
?2. response.data.condidates.map((элемент, индекс) => { dataCondidate.push(элемент) }) этот файл выполняет другую функцию
Ответ №1:
Для меня это просто звучит как фильтр. Разве ты не можешь просто сделать что-то подобное:
setNames(names.filter(name => !response.data.players.includes(name.label)))
Для справки, вот что работает без React:
const names = [{
value: "player1",
label: "player1"
},
{
value: "player3",
label: "player3"
},
{
value: "player2",
label: "player2"
},
{
value: "player5",
label: "player5"
},
];
const response = {
data: {
players: ["player1", "player2"],
},
};
const filteredNames = names.filter(name => !response.data.players.includes(name.label))
console.log(filteredNames);
Комментарии:
1. Это всегда отличный вариант, чтобы сделать код выполнимым.
Ответ №2:
Вы можете эффективно достичь результата, используя набор и фильтр
const names = [
{ value: "player1", label: "player1" },
{ value: "player3", label: "player3" },
{ value: "player2", label: "player2" },
{ value: "player5", label: "player5" },
];
const players = ["player1", "player2"];
const set = new Set(players);
const result = names.filter(({ label }) => !set.has(label));
console.log(result);
Комментарии:
1. Я раньше не пользовался набором, он для меня новый. Я прочитаю об этом. Также я попробовал код, и он сработал. Я действительно ценю вашу помощь:)
2. Он добавлен,
ES6
и если у вас очень большой наборplayers
данных, то лучше использоватьhas
методSet
проверки на наличие, а неincludes
anarray
.has
оптимизирован для проверки наличия. Если у вас небольшой набор данных, вы можете использовать любой из них. Счастливого обучения 😊