vben admin / ant design 的 Form表单获取/设置/清空某个表单项的值 , 使用 setFieldsValue 设置某个字段的时候,表单被清空的解决方案

文章讲述了在Vue3+TS项目中使用Vben框架时遇到的一个问题,即如何在客户下拉列表选择变化时清空关联的工地下拉列表,同时保持其他表单字段不变。作者通过尝试和错误找到了解决方案,涉及到表单字段的值管理,包括使用setFieldsValue可能导致的其他字段被清空的问题,以及使用深拷贝来避免这个问题。

项目场景:

项目当中用了 vben 框架, vben 是基于 ant design 封装的,项目中有个需求是一个筛选表单,其中筛选条件中通过下拉列表来完成,两个筛选下拉列表有着联动关系


在这里插入图片描述上图是期望的实现结果,客户和工地有着层级关系,当客户切换,对应工地列表会重新加载,而且选中状态清空,其他的选项不变

问题描述

这里在写的时候,一开始的思路是在所属客户的选中事件中清空工地这个字段的值
但是 vue3 + ts 是真的真的不熟悉啊啊啊啊

总之来看看代码叭

    <div class="bg-white mb-2 p-4">
      <BasicForm @register="registerForm" ref="formRef" />
    </div>
//过滤表单相关的代码
  const searchSchemas: FormSchema[] = [
    {
   
   
      field: 'state',
      component: 'Select',
      label: '设备状态',
      colProps: {
   
    span: 4 },
      componentProps: {
   
   
        allowClear: true,
        dictType: 'bu_device_status',
      },
    },
    {
   
   
      field: 'name',
      component: 'Input',
      colProps: {
   
    span: 4 },
      label: '设备名称'
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值