react---之下拉菜单默认选中的值始终不变的问题

需求:点击下拉菜单,出来主题列表选项,如果一个后台返回的组织已经有主题,那就默认选中该条选项。如果没有主题,那么默认第一个主题。
问题:后台返回了有主题的数据,但是下拉菜单一直显示是默认主题。
正确应显示下图(由于下拉列表会把下拉组件挡住,所以这边分开截图)。
如图:下拉框

 

下拉列表(测试数据)

主要代码如下:

select 是一个公用的下拉组件,在调用的时候传了defaultValue的值是挂载在state上的themeId

state上的themeId取值是后台返回的:

 

问题原因:
经过定位发现,应该是生命周期的问题,defaultValue,是页面渲染只能改变一次的值,在组件render之前是没有取到数据的,所以我给的是默认主题,render之后才会执行componentDidMount周期函数,此时我才拿到数据,但是defaultValue只能改变一次,我拿到数据后再去改变主题的值已经不起效了。

解决方案:
react是先执行render,再执行componentDidMount的,那么我在没加载到数据之前,不去render,由于数据结构的原因,我在组件render的时候加了如下代码

 

如上问题就解决了。

总结:组件的生命周期被实例话的时候执行的顺序是:

1、getDefaultProps
2、getInitialState
3、componentWillMount
4、render
5、componentDidMount 

是先执行render渲染页面的dom,然后再执行componentDidMount这个生命周期方法的。

 

转载于:https://www.cnblogs.com/yxfboke/p/10214429.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值