# React技巧之移除状态数组中的对象

原文链接:https://bobbyhadz.com/blog/react-remove-object-from-state-array (opens new window)

作者:Borislav Hadzhiev (opens new window)

正文从这开始~

# 总览

在React中,移除state数组中的对象:

  1. 使用filter()方法对数组进行迭代。
  2. 在每次迭代中,检查条件是否匹配。
  3. state设置为filter方法返回的新数组。
import {useState} from 'react';

export default function App() {
  const initialState = [
    {id: 1, name: 'Alice', country: 'Austria'},
    {id: 2, name: 'Bob', country: 'Belgium'},
  ];

  const [employees, setEmployees] = useState(initialState);

  const removeSecond = () => {
    setEmployees(current =>
      current.filter(employee => {
        // 👇️ remove object that has id equal to 2
        return employee.id !== 2;
      }),
    );
  };

  return (
    <div>
      <button onClick={removeSecond}>Remove second</button>

      {employees.map(({id, name, country}) => {
        return (
          <div key={id}>
            <h2>name: {name}</h2>
            <h2>country: {country}</h2>

            <hr />
          </div>
        );
      })}
    </div>
  );
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36

react-remove-object-from-state-array.gif

# Array.filter

我们使用useState 钩子初始化employees状态变量。

我们传递给Array.filter方法的函数将在数组的每个元素中被调用。在每次迭代中,我们检查对象中的id属性是否不等于2,并返回结果。

const initialState = [
  {id: 1, name: 'Alice', country: 'Austria'},
  {id: 2, name: 'Bob', country: 'Belgium'},
];

const filtered = initialState.filter(obj => {
  // 👇️ returns truthy for all elements that
  // don't have an id equal to 2
  return obj.id !== 2;
});

// 👇️ [{id: 1, name: 'Alice', country: 'Austria'}]
console.log(filtered);
1
2
3
4
5
6
7
8
9
10
11
12
13

filter方法返回一个新数组,该数组只包含回调函数返回真值的元素。

如果所有条件都不匹配,Array.filter函数将会返回空数组。

我们将函数传递到setState ,因为函数保证以当前(最新的)状态调用。

const removeSecond = () => {
  // 👇️ current is the current state array
  setEmployees(current =>
    current.filter(employee => {
      return employee.id !== 2;
    }),
  );
};
1
2
3
4
5
6
7
8

当使用前一个状态计算下一个状态时,传递一个函数给setState。否则,如果我们所访问的state数组不代表最新的值,我们可能会得到一些奇怪的Race Condition。

# 逻辑与

如果需要基于多个条件来移除state数组中的对象,可以使用逻辑与以及逻辑或操作符。

const initialState = [
  {id: 1, name: 'Alice', country: 'Austria'},
  {id: 2, name: 'Bob', country: 'Belgium'},
  {id: 3, name: 'Carl', country: 'Austria'},
];

const [employees, setEmployees] = useState(initialState);

const remove = () => {
  setEmployees(current =>
    current.filter(employee => {
      return employee.id !== 3 && employee.id !== 2;
    }),
  );
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

我们使用了逻辑与操作符,如果两边的条件都满足,将会返回真值。

# 逻辑或

下面是使用逻辑或操作符的例子。

const initialState = [
  {id: 1, name: 'Alice', country: 'Austria'},
  {id: 2, name: 'Bob', country: 'Belgium'},
  {id: 3, name: 'Carl', country: 'Austria'},
];

const [employees, setEmployees] = useState(initialState);

const remove = () => {
  setEmployees(current =>
    current.filter(employee => {
      return employee.name === 'Alice' || employee.name === 'Carl';
    }),
  );
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15

2个条件中的任何一个都必须评估为真值,才能将该元素添加到新数组中。换句话说,如果对象上的name属性等于Alice或等于Carl,该对象将被添加到新数组中。所有其他的对象都会从数组中被过滤掉。