react select默认选项_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这个生命周期方法的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值