【问题标题】:React hooks - Remove multi items from array and update stateReact hooks - 从数组中删除多项并更新状态
【发布时间】:2020-02-20 03:41:56
【问题描述】:

如何删除多个数组并设置状态?我从复选框中选择了多个项目。这是选中的项目 [5, 4, 3] 我想根据 id 删除数组中的所有项目并更新状态。这是我的代码。

const [products, setProducts] = useState();

 const DeleteProducts = () => {
  const selectedItems = [5, 4, 3];

    selectedItems.forEach(function(p) {
      setProducts(products.filter(prd => prd.id !== p));
    });
}

它一次只删除一项,但我选择了 3 项。如何删除 3 个选定项目和产品状态? 谢谢

【问题讨论】:

标签: javascript reactjs react-hooks


【解决方案1】:

您在循环的迭代中调用 setProducts。您必须在过滤后调用 setProducts 以便它只触发一次状态更改

const [products, setProducts] = useState();

 const DeleteProducts = () => {
  const selectedItems = [5, 4, 3];
  let newProducts;
    selectedItems.forEach(function(p) {
      newProducts = products.filter(prd => prd.id !== p);
    });
  setProducts(newProducts);
}

更好的是,您可以像这样更快地过滤它而无需循环


const DeleteProducts = () => {
  const selectedItems = [5, 4, 3];
  const newProducts = products.filter(prd => selectedItems.indexOf(prd.id) >= 0);
  setProducts(newProducts);
}

【讨论】:

  • 谢谢你,我想你忘了在 newProducts 变量中实例化一个空数组,因为那会变成未定义的
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-08-08
  • 1970-01-01
  • 2023-03-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多