vue3 + tdesign 自定义校验规则

 实现点击是否进行自定义校验, 当选择时间之后点击确定自动关闭校验,

  <t-form-item label-width="150px" label="是否账期用户" name="settlementType">
      <div class="flex items-center">
        <d-checkbox
          v-model="formData.settlementType"
          :value="settlementType"
          :activeValue="settlementTypeActive"
        ></d-checkbox>
        <div v-if="formData.settlementType == settlementTypeActive">
          <t-select
            clearable
            v-model="formData.settlementPeriodType"
            :options="paymentDaysList"
            placeholder="请选择账期"
            class="w-170px"
          ></t-select>
        </div>
      </div>
    </t-form-item>
const INIT_STATUS = {
  settlementType: 2,
  settlementPeriodType: '',
}
const formData = ref({ ...INIT_STATUS })  
settlementType: [
    { required: true, message: '请选择账期', trigger: 'blur' },
    {
      validator: (value) => {
        if (value == 1 && !formData.value.settlementPeriodType) {
          return false
        } else {
          return true
        }
      },
      message: '请选择账期'
    }
  ]

逻辑:  利用 t-form-itemname属性绑定, 同时在rules下方定义规则, 使用 validator 自定义校验 判断check的值是否为服务器需要的值 , 我这边为选中是2 ,选中是1 , 默认定义值未2,判断check的值为1并且账期下拉select框为空是 就为false, 反知为true

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值