先給出demo, demo
有一個開始時間和一個結(jié)束時間,要求是開始時間必須小于結(jié)束時間
重現(xiàn)步驟:
2018-08-23
2018-08-22,此時結(jié)束時間那邊提示結(jié)束時間必須大于開始時間,目前為止沒問題2018-08-21,此時結(jié)束時間的錯誤提示還在,主要就是這一步,怎么再次校驗結(jié)束時間
在不使用RangePicker、不使用disabledDate、不自定義Form的validateStatus、help等的情況下,怎么再次校驗呢? 我在DatePicker的onChange中調(diào)用了validateFieldsAndScroll`,好像沒啥用
兩個日期框都加自定義校驗就可以了,其中一個例子,另一個自己判斷邏輯就好了
{
getFieldDecorator('date1', { initialValue: moment(),
rules: [{
required: true,
validator: (rule, value, callback) => {
const edate = getFieldValue('date2');
if (moment(edate).isBefore(moment(value))) {
callback();
} else {
callback('you error message');
}
},
message:'日期必須大于xxx'
}]
})
(
<DatePicker
placeholder='日期1'
format='YYYY-MM-DD dddd'
onChange={date => { /*do something*/ }}
/>
)}我在你的代碼中添加了斷點調(diào)試了一下,發(fā)現(xiàn)了問題的原因:
validateFieldsAndScroll 可以傳個 { force: true } 作為第二個參數(shù)見文檔)),否則的話,未修改過的字段是不會再次觸發(fā)校驗的;onChange 中拿到的值是新的值,但這個值還沒有更新到組件的 state 中,也就是說,此時你調(diào)用 form.getFieldValue('timeStart') 拿到的值還是老的值;針對上面的原因,解決方案也比較清楚了:
validateFieldsAndScroll 添加 { force: true } 參數(shù);form.validateFieldsAndScroll 的調(diào)用放到 setTimeout(() => {}, 0) 里面北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產(chǎn)業(yè)為響應國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復興的升級產(chǎn)業(yè)鏈。利用北京大學優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓領域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。