Vue ElementUI之Form表单验证遇到的问题
首先说一下 我在form表单里面遇见的坑:
1.例如我要给后台传的不是对象,而是一个数组,怎么写验证?
2.比如我有四个弹出框,都要做验证,这个时候就要注意了,每一个弹出框的ref都不能给的一样,并且一定要与当前弹框的确定或者保存按钮一一对应,例如:第一个弹框的ref='number',按钮的click比如为xxxxxx('number'),第二个弹出框的ref=‘number2',对应的按钮>>xxxxxx('number2')。如果ref用的都一样,就会出现,点击下一步我没有去做验证,我再点击上一步,再点击下一步,控制台就会报错!
官网给的列子是在<el-form>里面进行验证,(当然也可以不用再标签里面进行验证,这里我重要说在标签里!!!),标签上要绑定一个对象(例,:model='numbervalidateform'
),注意:model绑定的必须是一个对象,如果是一个数组怎么办呢?这个下面再说,ref="numbervalidateform"
是什么呢,我要对表单进行验证,当然少不了确定或者保存按钮,名字需要和按钮一一对应,这样才能实现 点击保存的时候去验证输入框,上图!
好,接下来就要我们解决上面说的数组的问题了,如果我要传给后台的是一个数组,不是对象,我要怎么去做验证呢?直接上代码。
let flag = true; if (this.$refs[formname] instanceof array && this.$refs[formname].length > 0) { this.$refs[formname].foreach((obj, index) => { obj.validate((valid) => { if (valid) { console.log('验证成功!'); } else { console.log('error submit!!'); flag = false; return false; } }); }); if (flag) { this.seconddialog = false; this.thirddialog = true; } }
当然,你要是觉得麻烦,也可以用jq的方法去做验证,这样简单一点:(判断输入框paramname 是否为空,如果为空,显示错误提示信息,否则不显示)
let flag = true; this.requestparamslist.map((data, index) => { if (data.paramname == "") { $(".jqueryvalidate").eq(index).show(); flag = false; } });
最终效果图如下:
总结
以上所述是小编给大家介绍的vue elementui之form表单验证遇到的问题,希望对大家有所帮助
上一篇: vue.js异步上传文件前后端实现代码
推荐阅读
-
vue elementui el-form rules动态验证的实例代码详解
-
HTML5 form标签之解放表单验证、增加文件上传、集成拖放的使用方法
-
浅谈vue同一页面中拥有两个表单时,的验证问题
-
vue elementui form表单验证的实现
-
vue form check 表单验证的实现代码
-
Vue ElementUI之Form表单验证遇到的问题
-
Vue使用vux-ui自定义表单验证遇到的问题及解决方法
-
vue中使用ElementUI组件中的el-table遇到的问题
-
vue2之简易的pc端短信验证码的问题及处理方法
-
vue+element-ui集成随机验证码+用户名+密码的form表单验证功能