Element-ui表单验证不起作用,解决过程

根据表单自定义方法进行表单验证

1、在进行表单上传的过程中,一定要对表单进行验证,(一来可以规范客户输入,二来可以减轻服务端的压力,前端做一次拦截)在做烟草养护自动湖检测系统的数据预警的过程中,新建预警规则,里面的上限和下限需要限定是double类型的数据(需求)。

2、html的解决思路是再input光标失去焦点以后,便触发一个方法,返回一个boolean值,多个input就保存到多个全局变量中,最后在表单提交的过程中,对多个变量的值进行短路与操作,如果最后的值为true,则进行表单提交,如果为false则进行提示(思路)。

3、项目中用的是VUE+ELEMENT框架,利用的表单提交也是ELEMENT框架自带的.有兴趣的小伙伴可以参考一下(实现)。

4、按照ElEment官方API文档上一步一步的来,最终走到了最后,然而发现,在提交的过程中没有反应,Are you Kidding me?
到底是为什么? 我明明按照官网写的啊。。。(问题)

5、算了重新来过,经过自己一步一步排查,发现自己的验证方法好像跟官方的有一些差异.(解决)

原先我的代码是这样的

      var validatorUpper = (rule, value, callback) => {
      var reg = /^[-\+]?\d+(\.\d+)?$/
      if (value === '') {
        return callback('上限阙值不能为空')
      }
      if (!reg.test(value)) {
        return callback('请输入小于两位数的数字')
      } 
    }

官方代码是这样的

var checkAge = (rule, value, callback) => {
        if (!value) {
          return callback(new Error('年龄不能为空'));
        }
        setTimeout(() => {
          if (!Number.isInteger(value)) {
            callback(new Error('请输入数字值'));
          } else {
            if (value < 18) {
              callback(new Error('必须年满18岁'));
            } else {
              callback();
            }
          }
        }, 1000);
      };

原来是判断以后如果没有错的话,并没有返回一个callback,都怪自己太大意,特此记录。
另外有哪些写的不好的地方,还请多多指正。

总结

编程一定要细心!! 加油。

你可能感兴趣的:(Element)