相关疑难解决方法(0)

你可以强制React组件重新渲染而不调用setState吗?

我有一个外部(对组件),可观察的对象,我想听取更改.当对象更新时,它会发出更改事件,然后我想在检测到任何更改时重新呈现组件.

使用顶级React.render这是可能的,但在一个组件中它不起作用(这有一定意义,因为该render方法只返回一个对象).

这是一个代码示例:

export default class MyComponent extends React.Component {

  handleButtonClick() {
    this.render();
  }

  render() {
    return (
      <div>
        {Math.random()}
        <button onClick={this.handleButtonClick.bind(this)}>
          Click me
        </button>
      </div>
    )
  }
}
Run Code Online (Sandbox Code Playgroud)

单击按钮会在内部调用this.render(),但这不是实际导致渲染发生的原因(您可以看到此操作因为创建的文本{Math.random()}不会更改).但是,如果我只是打电话this.setState()而不是this.render(),它可以正常工作.

所以我想我的问题是: React组件需要有状态才能重新渲染吗?有没有办法强制组件按需更新而不改变状态?

reactjs react-jsx

608
推荐指数
12
解决办法
72万
查看次数

我可以在无状态组件中调用forceUpdate吗?

我有一个无状态组件,我想重新渲染它.我怎么能这样做?我试过用this,但没用.

我可以改用forUpdate或其他东西吗?

javascript reactjs

30
推荐指数
7
解决办法
2万
查看次数

标签 统计

reactjs ×2

javascript ×1

react-jsx ×1