首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无突变状态的反应滤波法

无突变状态的反应滤波法
EN

Stack Overflow用户
提问于 2017-03-20 02:08:52
回答 2查看 10.3K关注 0票数 5

我目前的状况是:

代码语言:javascript
复制
state = { items : [{id: 1, text: 'test words'}, {id: 2, text: 'another test'}]

下面是我的函数,用于从数组中移除对象,以避免发生变异状态。

代码语言:javascript
复制
handleRemove(passedInId) {

  const myItems = this.state.items

  const newArray = myItems.filter(item => item.id !== passedInId)

  this.setState(prevState => ({
    items: prevState.items = newArray
  }))

  console.log('handle remove runned', passedInId, myItems, newArray)

}

它工作得很完美,但想知道它是否是反模式,然后再继续我的生活。

非常感谢!!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-03-20 21:26:08

你的功能几乎是正确的,而且你有正确的想法。在您的情况下,您不需要使用接受mutator函数的setState版本,而只需这样做:

代码语言:javascript
复制
handleRemove(passedInId) {

  const myItems = this.state.items

  const newArray = myItems.filter(item => item.id !== passedInId)

  this.setState({
    items: newArray
  })

  console.log('handle remove runned', passedInId, myItems, newArray)

}

老实说,这很简单,一条线就行了:

代码语言:javascript
复制
handleRemove(passedInId) {
  this.setState({items: this.state.items.filter(item => item.id !== passedInId)})
}
票数 11
EN

Stack Overflow用户

发布于 2017-03-20 21:17:50

这是反模式。响应句柄状态更改,您的对象就不会发生变异。这就是setState的目的。我猜您不想更新您的状态以避免重新呈现您的组件。您可以创建类变量并按需要更新它,而无需触发重呈现。就像这样:

代码语言:javascript
复制
class MyComponent extends React.Component {
  constructor(props) {
    this.state = {};
    this.items = [{id: 1, text: 'test words'}, {id: 2, text: 'another test'}];
  }

  handleRemove(passedInId) {
    this.items = this.items.filter(item => item.id !== passedInId)
  }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42894774

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档