** 日期选择器无法正常使用年的形式**
在工作中使用3.x版本的antd,碰到日期选择器无法正常使用年的形式,发现网上的资料不多,自己研究了写了一下,亲测有用哦!
第一步:将DatePicker做成受控组件即绑定state的某个变量(本文使用的是year)。
第二步:使用onPanelChange方法将DatePicker选中的值赋给year,达到刷新视图的效果。
PS:一开始我试了onChange,调试的时候才发现选择日期的时候并不会触发onChange方法,这一步骤是为了解决日期选择器年形式无法赋值的问题。
第三步:使用onOpenChange方法将open设置为true,使用onPanelChange方法将
open设置为true,这样就能选择日期时显示日期面板,选完之后关闭日期面板。
PS:open属性是控制日期面板的显隐,把值设上去之后你会发现日期面板关闭不了,所以open也应该设置为受控的,将open与state的某个变量绑定(本文使用的是open),open的原始值设置为false,使用onOpenChange方法在弹出日历的时候显示日期面板即将open的值设置为true,在选中值后使用OnPanelChange方法隐藏日期面板即将open的值设置为false,这一步骤时是解决把日期选上去之后无法关闭日期面板的问题。
第四步:使用onBlur方法将open设置为false。
PS:你把日期选上了之后,虽然能关闭日期面板,但是如果打开了日期面板之后,你点击日期面板外的地方,日期面板也应该隐藏。
第五步:使用onChange清空日期选择器的值即将year的值清空。
PS:你把值设上去之后会发现,你点清除按钮没有效果,但是这个时候会触发onChange方法,可以利用这个方法清空日期选择器的值。
最后附上代码,希望帮到有需要的人。
//解决了把日期选上去的问题
onPanelHandler = (value) =>{
this.setState({
year:value,
open:false
})
}
//解决了无法关闭日期面板的问题
onOpenHandler = () => {
this.setState({
open:true
})
}
//解决了失焦不能关闭日期面板的问题
onBlurHandler = () => {
this.setState({
open:false
})
}
//解决了点击清除按钮无法清除值的问题
onChange = () => {
this.setState({
year:''
})
}
<DatePicker
mode="year" format={yearFormat} value={this.state.year}
onChange={this.onChange}
onBlur = {this.onBlurHandler}
open = {this.state.open}
onPanelChange = {this.onPanelHandler}
onOpenChange = {this.onOpenHandler}
/>