vue elementUI之Form表單 驗證


首先說一下 我在form表單里面遇見的坑:

1.例如我要給后台傳的不是對象,而是一個數組,怎么寫驗證?

2.比如我有四個彈出框,都要做驗證,這個時候就要注意了,每一個彈出框的ref都不能給的一樣,並且一定要與當前彈框的確定或者保存按鈕一一對應,例如:第一個彈框的ref='number',按鈕的click比如為xxxxxx('number'),第二個彈出框的ref=‘number2’,對應的按鈕>>xxxxxx('number2')。如果ref用的都一樣,就會出現,點擊下一步我沒有去做驗證,我再點擊上一步,再點擊下一步,控制台就會報錯!

官網給的列子是在<el-form>里面進行驗證,(當然也可以不用再標簽里面進行驗證,這里我重要說在標簽里!!!),標簽上要綁定一個對象(例,:model='numberValidateForm'),注意:model綁定的必須是一個對象,如果是一個數組怎么辦呢?這個下面再說,ref="numberValidateForm" 是什么呢,我要對表單進行驗證,當然少不了確定或者保存按鈕,名字需要和按鈕一一對應,這樣才能實現 點擊保存的時候去驗證輸入框,上圖!

開始驗證:(創建彈框的確定按鈕 調用的函數,詳情看最后一張圖)

 

 

addgroupList(formName) {
    this.$refs[formName].validate((valid) => {
      if (valid) {
        const groupName = xxxxxxxxxxxx;
        const description = xxxxxxxxxxxx;
        axios({
          method: 'post',
          url: 'xxxxxxxxxxxxxxxxxxxxx',
          data: {
            groupName: xxxxxxxxxxxxx,
            groupDescription: xxxxxxxxxxxxxxx
          }       
        }).then(res => {
          this.creatGroup = false;
          this.searchGroupName = '';
          this.initData();
        }).catch(error => {
          console.log('網絡錯誤,不能訪問');
        });
      } else {
          console.log('error submit!!');
          return false;
        }
      });
   },

 

好,接下來就要我們解決上面說的數組的問題了,如果我要傳給后台的是一個數組,不是對象,我要怎么去做驗證呢?直接上代碼。

 1 let flag = true;
 2       if (this.$refs[formName] instanceof Array && this.$refs[formName].length > 0) {
 3         this.$refs[formName].forEach((obj, index) => {
 4           obj.validate((valid) => {
 5             if (valid) {
 6               console.log('驗證成功!');
17 } else { 18 console.log('error submit!!'); 19 flag = false; 20 return false; 21 } 22 }); 23 }); 24 25 if (flag) { 26 this.secondDialog = false; 27 this.thirdDialog = true; 28 } 29 }

 

當然,你要是覺得麻煩,也可以用JQ的方法去做驗證,這樣簡單一點:(判斷輸入框paramName 是否為空,如果為空,顯示錯誤提示信息,否則不顯示)

1 let flag = true;
2   this.requestParamsList.map((data, index) => {
3         if (data.paramName == "") {
4           $(".jqueryValidate").eq(index).show();
5           flag = false;
6         }
7     });

最終效果圖如下:

以上就是今天給大家分享的內容,希望大家多多提出自己的建議,謝謝

 

 

 

如果我的內容對你有幫助,歡迎打賞


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM