antd Form组件initialValues属性在React17中延迟渲染问题

需求是点击修改框 然后显示一个Modal框,里面有点击部门的相关权限
在这里插入图片描述
在这里插入图片描述
把点击的数据传进Form组件initialValues,出现bug 数据改变了但是默认值为上一次点击的值!!

可以看到化工学院的值变成上一次点击的信息学院的值


再次点击恢复正常
在这里插入图片描述
再点信息学院,变成化工学院
在这里插入图片描述
关键代码:

      <Modal destroyOnClose={true} title={state.DepartmentName} visible={state.isModalVisible} onOk={handleOk} onCancel={handleCancel}>
        <Form
          preserve={false}
          form={form}
          name="basic"
          labelCol={{
            span: 4,
          }}
          wrapperCol={{
            span: 20,
          }}
          initialValues={
            {
              router: state.InitRoute,
              api: state.InitApi,
            }}
          onFinish={onFinish}
          onFinishFailed={onFinishFailed}
          autoComplete="off"
        >
          <Form.Item
            label="路由权限"
            name="router"
          >
            <Checkbox.Group options={routeList.map((value) => {
              return { value: value.routeId, label: RouterMaper.get(value.routeName) }
            })}
            />
          </Form.Item>

          <Form.Item
            label="操作权限"
            name="api"
          >
            <Checkbox.Group options={apiList.map((value) => {
              return { value: value.apiId, label: ApiMaper.get(value.apiName) }
            })} />
          </Form.Item>
        </Form>
      </Modal>

修改成下面代码后(把初始值直接赋给Checkbox),解决:

		<Modal destroyOnClose={true} title={state.DepartmentName} visible=	{state.isModalVisible} onOk={handleOk} onCancel={handleCancel}>
		
        <Checkbox.Group defaultValue={state.InitRoute} options={routeList.map((value) => {
          return { value: value.routeId, label: RouterMaper.get(value.routeName) }
        })}
        />
        <Checkbox.Group defaultValue={state.InitApi} options={apiList.map((value) => {
          return { value: value.apiId, label: ApiMaper.get(value.apiName) }
        })} />
      </Modal>

解决
在这里插入图片描述
在这里插入图片描述
人麻了,我一开始以为是React的问题,是不是useState异步导致的,改成useReduce还是不行,这才想到是不是antd的问题

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值