как удалить элемент из массива

#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 an array . has оптимизирован для проверки наличия. Если у вас небольшой набор данных, вы можете использовать любой из них. Счастливого обучения 😊