2017-08-10 47 views
0

我使用嚮導單擊下一步按鈕不檢查使用正則表達式驗證電子郵件。 我已經使用開關盒第一空白輸入顯示錯誤,否則進入下一步,並添加電子郵件輸入值錯誤後不檢查電子郵件這個值在Reg如何解決這個問題。如何查看電子郵件有效性?

<form> 
    <div class="form-main"> 
    <div class="form-input"> 
     <input type="text" id="fname" placeholder="First Name"> 
     <p id="error"></p> 
    </div> 
    <div class="form-input"> 
     <input type="text" id="lname" placeholder="Last Name"> 
     <p id="error"></p> 
    </div> 
    <div class="form-input"> 
     <input type="email" id="email" placeholder="Email"> 
     <p id="error"></p> 
    </div> 
    <div class="form-input"> 
     <input type="password" id="password" placeholder="Password"> 
     <p id="error"></p> 
    </div> 
    <div class="form-btn"> 
     <button type="button" id="prev" onClick="prevBtn(this);">prev</button> 
     <button type="button" id="next" onClick="nextBtn(this);">next</button> 
     <button type="submit" id="submit">submit</button> 
    </div> 
    </div> 
</form> 

首先是讓變量的正則表達式中進行函數emailValidate名稱,在此功能中採用可變mailFormate這回文本電子郵件。此功能用於切換情況下,如果輸入值爲空白,則顯示錯誤,否則檢查輸入類型文本和電子郵件,但電子郵件爲空白如果添加電子郵件格式時顯示錯誤,則不檢查RegEx跳過下一步如何解決此問題。

$(window).on('load',function(){ 
     $('.form-main > .form-input:nth-child(1)').addClass('open'); 
     $('.form-main > .form-input:not(".open")').addClass('close').hide();  
    }); 

    var $div = $('.form-input'); 
    var submits = $('#submit').css('display','none'); 
    index = 0; 

    function updateStatus(a){ 
     $div.eq(index).removeClass('current').addClass('close').hide(); 
     index += a; 
     $div.eq(index).addClass('current').removeClass('close').show(); 

     $('#next').toggle((index !==$div.length-1)); 
     $('#prev').toggle(index !== 0); 

     if(index == ($div.length - 1)){ 
      submits.toggle(index !== 0); 
     }else{ 
      submits.hide(); 
      } 
    } 

    var input = document.getElementsByTagName('input'); 
    var error = document.getElementById('error'); 

    var regEx = { 
     emailValidate : function emailValidate(email){ 
     var mailFormate = /^(([^<>()\[\]\\.,;:\[email protected]"]+(\.[^<>()\[\]\\.,;:\[email protected]"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/; 
      return mailFormate.test(email); 
     } 
    } 


    function validation(){ 
     var inputValue = $('input:visible').val(); 
     var inputType = $(input).attr('type'); 

     if(inputValue !== ''){ 
     switch(inputType){ 
      case 'text' :{ 
       updateStatus(+1); 
      } 

      case 'email' :{ 
       var email = regEx.emailValidate(inputValue); 
        if(!email){ 
         error.innerHTML = "please enter valid mail"; 
         return false; 
        }else{ 
         error.innerHTML = "valid"; 
         updateStatus(+1); 
        } 
        break; 
       } 
       default : ''; 
      } 

     }else{ 
      $('input:visible').next().html("please enter the value"); 
      } 
    } 

    function nextBtn(){ 
     validation(); 
    } 

    function prevBtn(){ 
     updateStatus(-1); 
     error.innerHTML = ''; 
    } 
+0

你可以在輸入標籤中設置模式屬性吧? – Jok3r

+0

是的,正確的mailFormate是電子郵件模式。 – Dhaval

+0

''點擊「提交」檢查電子郵件驗證,如果電子郵件無效 –

回答

0

<!DOCTYPE html> 
 
<html> 
 
<body> 
 

 
<form> 
 
Email: <input type="email" name="country_code" pattern="^[a-z0-9._%+-][email protected][a-z0-9.-]+\.[a-z]{2,4}$" > 
 
    <input type="submit"> 
 
</form> 
 

 

 
</body> 
 
</html>

試試這個,

+0

將顯示相應的錯誤,這將自動生成錯誤警告,直到用戶以正確的格式輸入電子郵件,試試吧,祝你好運:) – Jok3r

+0

如果它爲你工作,請投票給我的答案。比你:) – Jok3r

+0

但提交按鈕顯示最後一步和最後一步是密碼,所以之前檢查電子郵件驗證他的有效,所以去下一步,我只使用正則表達式使用函數顯示上面的JS代碼的JavaScript。 – Dhaval

0

<!DOCTYPE html> 
 
<html> 
 
<head> 
 
    
 
    <meta charset="utf-8"> 
 
    <meta name="viewport" content="width=device-width, initial-scale=1"> 
 
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css"> 
 
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script> 
 
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script> 
 
    <link rel="stylesheet" href="http://cdnjs.cloudflare.com/ajax/libs/jquery.bootstrapvalidator/0.5.3/css/bootstrapValidator.min.css"/> 
 
    <script type="text/javascript" src="http://cdnjs.cloudflare.com/ajax/libs/jquery.bootstrapvalidator/0.5.3/js/bootstrapValidator.min.js"> </script> 
 
    <script src="https://cdnjs.cloudflare.com/ajax/libs/1000hz-bootstrap-validator/0.11.5/validator.min.js"></script> 
 
</head> 
 
<body> 
 

 
<form data-toggle="validator" role="form"> 
 
    
 
           <div class="form-group has-feedback"> 
 
            <label for="Email" class="control-label"><b>Email</b></label> 
 
            <input type="text" class="form-control" id="umail" data-minlength="5" placeholder="Email" name="umail" pattern="^[a-z0-9._%+-][email protected][a-z0-9.-]+\.[a-z]{2,4}$" required> 
 
            <span class="glyphicon form-control-feedback" aria-hidden="true"></span> 
 
            <div class="help-block with-errors"></div> 
 
           </div> 
 
          <input type="submit"> 
 
</form> 
 

 

 
</body> 
 
</html>

嘗試。這是通過引導驗證器插件完成的

+0

好吧,我嘗試,但客戶說不使用bootstrap.Thank你幫我 – Dhaval

+0

反正我的回答幫助你或不? – Jok3r

+0

有幫助我你的答案。 – Dhaval