请教各位一个问题,求解答:如何避免react(dva.js)多次渲染?

问题描述:当在浏览器中刷新页面时,如下示例代码:
classTestextendsComponent{
constructor(props){
super(props)
this.state={}
}
componentWillMount(){
//获取所有活动数据
...code
}
render(){
const{Test}=this.props;
console.log(Test)
return(
这是一段测试代码
)
}
会发现在浏览器后台打印出多次Test,其中前几次多为空对象,那么应该如何避免这种情况呢?
繁星淼淼
浏览 292回答 2
2回答

跃然一笑

shouldComponentUpdate是可以控制是否渲染更新的classTestextendsComponent{constructor(props){super(props)this.state={}}componentWillMount(){//获取所有活动数据...code}shouldComponentUpdate(nextProps){if(isEqual(nextProps.Test,this.props.Test){returnfalse}}render(){const{Test}=this.props;console.log(Test)return(这是一段测试代码)}

心有法竹

1、如果代码结构正确,这种多次渲染并不会存在问题(没获取到数据之前为空,得到数据再次渲染,正常现象),当然如果没正确控制好代码渲染,就会带来各种bug2、如果想减少不必要渲染,使用shouldcomponenmtupdate
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript