为了账号安全,请及时绑定邮箱和手机立即绑定

react中异步验证表单应该如何写?

react中异步验证表单应该如何写?

偶然的你 2018-12-13 18:14:12
场景如下:有一个input,用户可以输入url地址,然后需要通过请求这个url地址通过返回的状态码是否为200才能走下一步。stepOne.jsxstepController.jsx可是问题是除了这一步验证url之外,其他的所有判断是否合法都是同步判断.所以就直接在checkData无误后把值返回到stepController了。可是我岂不是为了这一个异步判断要把stepController里的所有return都放在then或者catch里?大家有什么优雅一点的方法嘛?目录结构
查看完整描述

1 回答

?
慕桂英3389331

TA贡献2036条经验 获得超8个赞

不要去管同步还是异步,每一步校验完成后的状态都调用setState保存,校验的结果通过state体现,而不要根据checkCurrentStep的返回值是true还是false

创建一个容器组件Container,负责校验逻辑,stepController里的逻辑也写在这里。每一个步骤的页面对应一个组件Step1、Step2、Step3...当需要校验页面数据时,页面组件通过props调用Container的stepController方法,stepController完成校验后setState,state类似这样的结构:{page1: {data: XXX, validate: true}, page2:{data: XXX, validate: true}},把state传递给各个页面组件,在页面组件的componentWillReceiveProps()中判断props的变化,当nextProps.validate为true时,表示验证通过,在这个方法中执行跳转到下个页面的逻辑。


查看完整回答
反对 回复 2019-01-16
  • 1 回答
  • 0 关注
  • 573 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信