需求:多個表單,我想一起校驗一起提交,比如這里的上下兩個部分為兩個組件,兩個form表單
功能點:1.所有報表需通過校驗
2.通過校驗后提交並帶入所有參數
核心問題:form表單的validateFields()返回的是一個promise對象,也就是說他是一個異步方法,對標的的校驗必定有異步問題.而且無論前一個表單校驗成功與否,后一個表單都需要繼續校驗.只不過只要有不通過的,就不提交.
解決方案:
1.無論成功與否都需要繼續,即不分前后. Promise.all()
2.校驗接受后需要拿到對應的表單值 .新建一個promise對象,res返回對應表單values.失敗即返回失敗
所以,把每個表單的校驗過程都注冊成一個promise對象,在validateFields().then()里面返回values,在.catch返回失敗信息,然后用Promise.all()統一提交和監聽,在.then()里面能拿到所有表單返回的values,然后統一處理提交.
代碼:
formList.length > 0 && formList.map((item, index) => { let promiseObj = new Promise((res, rej) => { item.form .validateFields() .then((values) => { res(values); }) .catch((error) => { rej('失敗'); }); }); arr.push(promiseObj); }); Promise.all(arr) .then((res) => { if (res.length > 0) { res.map((item) => { allParams = { ...allParams, ...item }; }); dispatch({ type: 'common/submit', payload: { ...allParams }, }); } }) .catch((error) => { console.log('error', error); });