编辑:经过进一步测试,我意识到 componentDidMount 的行为符合我的预期,但这似乎是我的随机函数的一个问题,如果它再次运行,由于某种原因返回未定义,所以在初始安装时它会给我结果,当我再次安装它时,它返回未定义,因此没有任何渲染......
我进行了研究以了解为什么我会遇到这个问题。我有一个 webapp 组件,它只是一个将呈现赞助商名称的横幅。每次渲染此横幅时,我都想随机化赞助商出现的顺序。我可以让它工作,但它只在第一次渲染时发生(在 componentDidMount() 上),然后每次我访问该组件被渲染的任何部分时,它不再调用 componentDidMount(),因此它不渲染任何内容。
起初我认为 componentDidMount() 应该在每次进入调用该组件的部分时调用。阅读后,到处都说组件被安装一次,这就是为什么它只调用一次函数。我怎样才能让它在每次渲染组件时随机化?
这是我正在编写的代码示例。
class SponsorBanner extends React.Component {
constructor(props){
super(props)
this.state = {
randomized: []
}
this.randomizeSponsors = this.randomizeSponsors.bind(this)
}
randomizeSponsors(){
let copy = []
const array = ['a','b','c','d']
let n = array.length
let i;
while(n){
i = Math.floor(Math.random() * n--)
copy.push(array.splice(i,1)[0])
}
let randomizedArray = copy.map((sponsor,i) => <div key={i}>{sponsor}</div>)
this.setState({randomized:randomizedArray})
}
componentDidMount(){
this.randomizeSponsors()
}
render(){
return (
<div>
{this.state.randomized}
</div>
)
}
}
该组件在应用程序的 2 个不同部分中呈现。这是一个非常简单的应用程序,我什至没有向它添加路由。它只是完全作为一个 SPA 工作。当用户单击一个部分时,它会呈现该组件。在第一次加载时,如果我访问呈现此组件的部分,它会显示一个随机数组。如果我导航到另一个部分并返回,它会呈现一个空横幅。
为什么会发生这种情况,我该如何解决?