vue使用避坑汇总

  1. 配合antdesign-vue(V2) 进行表单validate的时候,设置了blur或者change,validate不能生效

如下:

ini 复制代码
 <a-form-item label="扶持配额" name="daySupportSum">
      <span class="i-dollar">$</span>
      <a-input-number 
          v-model:value="formState.daySupportSum"
          placeholder="金额≤999"
          :step="0.01"
          :precision="2"
          allow-clear
          prefix="$"
          class="w30 fc-sq" />
</a-form-item>

解决方式: 需把表单元素放到第一个位置

  1. 表单item拥有大于1个表单元素的时候,如何触发validate ?

解决方式:

  • 为dateTime设置好规则,
  • 当formState.dateTimeS与formState.dateTimeE 其中一项更改的时候,给formState.dateTime赋值
ini 复制代码
<a-form-item label="时间" name="dateTime">
      <a-date-picker  v-model:value="formState.dateTimeS"/> 
          <span class="line">-</span> 
      <a-date-picker v-model:value="formState.dateTimeE" />
</a-form-item>

js代码:

scss 复制代码
const formState = reactive({
    fcTime: [],
    fcTimeS: undefined,
    fcTimeE: undefined,
})

watch(() => formState.dateTimeS, (val) => {
  formState.dateTime = [formState.dateTimeS, formState.dateTimeE]
})

watch(() => formState.dateTimeE, (val) => {
  formState.fcTime = [formState.dateTimeS, formState.dateTimeE]
  formRef.value.validateFields(['dateTime'])
})

rule规则:

js 复制代码
dateTime: [
    {
      required: true,
      trigger: ['change', 'blur', 'submit'],
      message: '上课时间不能为空',
      type: 'array',
      validator: (rule, value) => {
        if (!value || !value[0] || !value[1]) {
          return Promise.reject('上课时间不能为空')
        }
        return Promise.resolve()
      }
    }
],
  1. antDesignV2 如何实现动态表单的validate,

    如下:

相对比antdesignV2来,antDesignV3 实现动态表单的validate方便,

js 复制代码
<a-space v-for="(sight, index) in dynamicValidateForm.sights" :key="sight.id"> 
     <a-form-item 
         :name="['sights', index, 'value']" 
         label="Sight" 
         :rules="{ required: true, message: 'Missing sight', }" > 
         <a-select v-model:value="sight.value"
             :options="(sights[dynamicValidateForm.area] || []).map(a => ({ value: a }))" >
         </a-select> 
      </a-form-item> 
      <a-form-item 
          label="Price" 
          :name="['sights', index, 'price']" 
          :rules="{ required: true, message: 'Missing price', }" 
      > 
          <a-input v-model:value="sight.price" /> 
      </a-form-item>
      <MinusCircleOutlined @click="removeSight(sight)" /> 
</a-space>

下面是antDesignV2的方式:

rules:

  • 通过makeRules函数
javascript 复制代码
const makeRules = (list) => {
      list.forEach((item) => {
        const ruleItem = {
          [`x x x-xxx-${item.id}`]: [
            {
              type: 'number',
              required: true,
              message: `请输入`,
              trigger: ['blur', 'change', 'submit'],
              validator: (rule, value) => {
                if (!value && value !== 0) {
                  return Promise.reject(`请输入`)
                }
                return Promise.resolve()
              }
            }
          ],
          [`xxx-xxx-${item.id}`]: [
            {
              type: 'array',
              required: true,
              message: `请选择`,
              trigger: ['blur', 'change', 'submit'],
              validator: (rule, value) => {
                if (!value || (value && !value.length)) {
                  return Promise.reject(`请选择`)
                }
                return Promise.resolve()
              }
            }
          ]
        }
        rulesObj = {
          ...rulesObj,
          ...ruleItem
        }
        return rulesObj
      })
    }
  • 通过makeRules(list)得到rules规则,然后给赋值给a-form的rules
ini 复制代码
 <a-form ref="formRef"
            :model="formState"
            :rules="rules"
            layout="vertical">   
      <div class="flex price-item" v-for="(item, index) of xxxList" :key="item.id">
          <a-form-item class="item-unit" label="xxx" :name="`price-${tabId}-${item.id}`">
            <a-input-number class="price-number" v-model:value="formState[`xxx-xxx-${item.id}`]" :min="0.01" />
          </a-form-item>
          <a-form-item class="item-unit" label="xxx" :name="`xxx-${tabId}-${item.id}`">
            <a-input v-model:value="formState[`country-${tabId}-${item.id}`]"/>
          </a-form-item>
          <DeleteOutlined class="delete-btn" @click="deletePriceItem(item.id, index, item)" />
    </div>
    </a-form>
相关推荐
子兮曰2 小时前
async/await高级模式:async迭代器、错误边界与并发控制
前端·javascript·github
恋猫de小郭2 小时前
2026 Flutter VS React Native ,同时在 AI 时代 VS Native 开发,你没见过的版本
android·前端·flutter
GIS之路4 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒6 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
Kagol7 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉7 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau7 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生7 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼7 小时前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范
明君879977 小时前
Flutter 如何给图片添加多行文字水印
前端·flutter