posts - 91,  comments - 2,  views - 11万

validateField用法

浏览器debug发现,每个字段,都会单独校验并返回校验结果;失败时,返回用户定义的错误提示信息;校验通过返回空串

方法一:

复制代码
  // 字段教校验时,每个字段都会单独校验一遍,将结果保存到数组中
  let validateFields = ['username', 'password', 'confirmPassword']
  let validateFieldsRs = []
  this.$refs.formName.validateField(validateFields, (valid) => {
    // 字段校验成功则返回空串
    if (!valid) {
      validateFieldsRs.push(valid)
    } else {
      return
    }
    // 数据元素个数和字段个数一致时,校验结束且都是成功的
    if (validateFields.length == validateFieldsRs.length && validateFieldsRs.every((item) => item === '')) {
      // 其他处理业务逻辑
    }
  })
复制代码

方法二:

复制代码
      Promise.all(validateFields.map((item) =>
          new Promise((resove, reject) => {
            // 返回校验结果
            this.$refs.formName.validateField(item, (err) => resove(err))
          })
        )
      ).then((res) => {
        // 过滤所有的非空串的,存在非空串表示校验不通过的
        if (res.filter((item) => item).length) {
          return
        }
        // 校验通过后,业务逻辑
      })
复制代码

 

posted on   le.li  阅读(356)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示