在 React 中从数组状态中删除项目
在 React 中,管理状态对于维护组件的内部数据至关重要。在处理状态数组时,保持不变性对于避免常见陷阱至关重要。
考虑从状态数组中删除项目的场景。一种常见的方法是使用 Array.prototype.delete() 来改变原始数组,如问题所示:
removePeople(e) { var array = this.state.people; var index = array.indexOf(e.target.value); delete array[index]; }
但是,在 React 中,建议避免直接改变状态。相反,创建包含所需更改的数组的新副本:
removePeople(e) { this.setState({people: this.state.people.filter(function(person) { return person !== e.target.value; })}); }
此方法利用 Array.prototype.filter() 方法创建一个新数组,其中包含除要删除的元素之外的所有元素。它不会改变原始数组,从而确保状态的不变性。
通过采用这种方法,您可以保持状态完整性并避免与 React 中的状态突变相关的潜在问题。
以上是如何在保持不变性的同时从 React 状态的数组中删除项目?的详细内容。更多信息请关注PHP中文网其他相关文章!