亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

BootstrapValidator驗(yàn)證用戶名已存在(ajax)

 更新時(shí)間:2019年11月08日 11:10:20   作者:Coder-HaN  
這篇文章主要為大家詳細(xì)介紹了BootstrapValidator驗(yàn)證用戶名已存在,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

Java web項(xiàng)目:bootstrap實(shí)現(xiàn)注冊(cè)頁(yè)面,mvc模式聯(lián)合mysql數(shù)據(jù)庫(kù)檢查用戶名的唯一性。

一、實(shí)現(xiàn)效果:

重置這里有bug,bootstrapValidator驗(yàn)證不能重置,待解決。

二、代碼準(zhǔn)備:

引入bootstrap,bootstrapValidator和jquery。

<link rel="stylesheet" href="<%=request.getContextPath() %>/css/bootstrap.min.css" rel="external nofollow" />
<link rel="stylesheet" href="<%=request.getContextPath() %>/css/bootstrapValidator.min.css" rel="external nofollow" />
<script src="<%=request.getContextPath() %>/js/jquery.min.js"></script>
<script src="<%=request.getContextPath() %>/js/bootstrap.min.js"></script> 
<script src="<%=request.getContextPath() %>/js/bootstrapValidator.min.js"></script>

三、部分代碼:

register.jsp注冊(cè)部分代碼。 

<form id="registerForm" action="<%=request.getContextPath() %>/UserServlet" method="post">
 <input type="hidden" name="method" value="register"/>
 <div class="form-group">
  <label>用戶名</label>
  <input type="text" class="form-control" name="userName" placeholder="用戶名由2-12位字符組成" />
 </div>

 <div class="form-group">
  <label>郵箱</label>
  <input type="text" class="form-control" name="userEmail" placeholder="郵箱" />
 </div>

 <div class="form-group">
  <label>密碼</label>
  <input type="password" class="form-control" name="userPassword" placeholder="密碼由6-10位字母數(shù)字組成" />
 </div>

 <div class="form-group">
  <label>確認(rèn)密碼</label>
  <input type="password" class="form-control" name="confirmUserPassword" placeholder="再次輸入密碼" />
 </div>

 <div class="form-group">
  <button type="submit" class="btn btn-primary">注冊(cè)</button>
  <input type="reset" class="btn btn-primary" value="重置">
 </div>
</form>

利用bootstrapValidator表單驗(yàn)證代碼。 ajax部分有詳細(xì)注釋

<script type="text/javascript">
 $(function() {
  $('#registerForm').bootstrapValidator({
   message: 'This value is not valid',
   feedbackIcons: {
    valid: 'glyphicon glyphicon-ok',
    invalid: 'glyphicon glyphicon-remove',
    validating: 'glyphicon glyphicon-refresh'
   },
   fields: {
    userName: {
     message: 'The username is not valid',
     validators: {
      notEmpty: {
       message: '用戶名不能為空'
      },
      stringLength: {
       min: 2,
       max: 12,
       message: '用戶名由2-12位字符組成'
      },
      threshold: 2,//有2字符以上才發(fā)送ajax請(qǐng)求
      remote: {//ajax驗(yàn)證。server result:{"valid",true or false} 
       url: "/ImageShare/UserServlet",
       message: '用戶名已存在,請(qǐng)重新輸入',
       delay: 1000,//ajax刷新的時(shí)間是1秒一次
       type: 'POST',
       //自定義提交數(shù)據(jù),默認(rèn)值提交當(dāng)前input value
       data: function(validator) {
       return {
        userName : $("input[name=userName]").val(),
         method : "checkUserName"http://UserServlet判斷調(diào)用方法關(guān)鍵字。
        };
       }
      }
     }
    },
    userEmail: {
     validators: {
      notEmpty: {
       message: '郵箱不能為空'
      },
      emailAddress: {
       message: '輸入不是有效的電子郵件地址'
      }
     }
    },
    userPassword: {
     validators: {
      notEmpty: {
       message: '密碼不能為空'
      },
      stringLength: {
       min: 6,
       max: 10,
       message: '密碼由6-10位字符組成'
      },
      identical: {
       field: 'confirmUserPassword',
       message: '密碼輸入不一致'
      }
     }
    },
    confirmUserPassword: {
     validators: {
      notEmpty: {
       message: '密碼不能為空'
      },
      stringLength: {
       min: 6,
       max: 10,
       message: '密碼由6-10位字符組成'
      },
      identical: {
       field: 'userPassword',
       message: '密碼輸入不一致'
      }
     }
    }
   }
  });
 });
</script>

UserServlet.java檢查用戶名唯一性部分代碼。

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
 // TODO Auto-generated method stub
 request.setCharacterEncoding("UTF-8");
 //0、獲取method判斷執(zhí)行操作
 String method = request.getParameter("method");
 if ("checkUserName".equals(method)) {
 //驗(yàn)證用戶名是否已存在
 checkUserName(request,response);
 }
}

//根據(jù)用戶名稱查詢,檢查用戶名稱的唯一性(用戶注冊(cè))
public void checkUserName(HttpServletRequest request, HttpServletResponse response) throws IOException{
 response.setCharacterEncoding("UTF-8");
 //返回json數(shù)據(jù),格式為{"valid",true} 表示合法,驗(yàn)證通過(guò)。{"valid":false} 表示不合法,驗(yàn)證不通過(guò)
 String jsonResult = "";
 String userName = request.getParameter("userName");
 //去數(shù)據(jù)進(jìn)行唯一性確認(rèn)
 if (userName!=null) {
 //服務(wù)層service調(diào)用數(shù)據(jù)庫(kù)訪問(wèn)層dao中的searchUserName方法。
 boolean b = UserServiceImpl.searchUserName(userName);
 if (b) {
 //如果名稱存在
 jsonResult = "{\"valid\":false}";
 }else{
 //如果該名稱不存在
 jsonResult = "{\"valid\":true}";
 }
 } else {
 jsonResult = "{\"valid\":false}";
 }
 //response把jsonResult打到前臺(tái)
 response.getWriter().write(jsonResult);
}

四、總結(jié):

1.利用bootstrapValidator的ajax表單驗(yàn)證用戶名已存在關(guān)鍵是自定義提交的數(shù)據(jù)。

2.將當(dāng)前input的value值和判斷操作方法的method關(guān)鍵字提交

3.注意當(dāng)server必需返回形如:{“valid”,true or false} 的json數(shù)據(jù)格式

4.servlet通過(guò) response.getWriter().write(jsonResult) 返回響應(yīng)的內(nèi)容jsonResult到前臺(tái)頁(yè)面。

如果大家還想深入學(xué)習(xí),可以點(diǎn)擊這里進(jìn)行學(xué)習(xí),再為大家附3個(gè)精彩的專題:

Bootstrap學(xué)習(xí)教程

Bootstrap實(shí)戰(zhàn)教程

Bootstrap插件使用教程

以上就是關(guān)于本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

相關(guān)文章

  • Javascript獲取與設(shè)置ckeditor數(shù)據(jù)的實(shí)現(xiàn)方法

    Javascript獲取與設(shè)置ckeditor數(shù)據(jù)的實(shí)現(xiàn)方法

    最近編輯器后臺(tái)升級(jí)成了ckeditor,但原來(lái)后臺(tái)有很多對(duì)應(yīng)編輯器內(nèi)容的替換功能,那么就需要用js獲取ckeditor編輯器里面的內(nèi)容,這里就為大家介紹一下具體的實(shí)現(xiàn)方法
    2023-08-08
  • TS?中?never,void,unknown類型詳解

    TS?中?never,void,unknown類型詳解

    這篇文章主要介紹了TS?中?never,void,unknown類型詳解,never?類型是 TypeScript 中的底層類型,unknown是TypeScript中比較特殊的一種類型,它用于描述類型不確定的變量,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • 瀑布流的實(shí)現(xiàn)方式(原生js+jquery+css3)

    瀑布流的實(shí)現(xiàn)方式(原生js+jquery+css3)

    這篇文章主要為大家詳細(xì)介紹了原生js+jquery+css3實(shí)現(xiàn)瀑布流的相關(guān)代碼,三種實(shí)現(xiàn)瀑布流的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-07-07
  • js實(shí)現(xiàn)仿百度瀑布流的方法

    js實(shí)現(xiàn)仿百度瀑布流的方法

    這篇文章主要介紹了js實(shí)現(xiàn)仿百度瀑布流的方法,以完整實(shí)例形式分析了js仿百度瀑布流的相關(guān)樣式與實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-02-02
  • javascript中setAttribute()函數(shù)使用方法及兼容性

    javascript中setAttribute()函數(shù)使用方法及兼容性

    這篇文章主要介紹了javascript中setAttribute()函數(shù)使用方法及兼容性的相關(guān)資料,需要的朋友可以參考下
    2015-07-07
  • JS控件bootstrap suggest plugin使用方法詳解

    JS控件bootstrap suggest plugin使用方法詳解

    這篇文章主要介紹了JS控件bootstrap suggest plugin的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • JavaScript獲取當(dāng)前url路徑過(guò)程解析

    JavaScript獲取當(dāng)前url路徑過(guò)程解析

    這篇文章主要介紹了JavaScript獲取當(dāng)前url路徑過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • JavaScript常用驗(yàn)證函數(shù)實(shí)例匯總

    JavaScript常用驗(yàn)證函數(shù)實(shí)例匯總

    這篇文章主要介紹了JavaScript常用驗(yàn)證函數(shù),實(shí)例匯總了如字符串驗(yàn)證、表單驗(yàn)證及js常用特效等諸多js常用驗(yàn)證函數(shù)及相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2014-11-11
  • JavaScript實(shí)現(xiàn)左右下拉框動(dòng)態(tài)增刪示例

    JavaScript實(shí)現(xiàn)左右下拉框動(dòng)態(tài)增刪示例

    本篇文章主要介紹了JavaScript實(shí)現(xiàn)左右下拉框動(dòng)態(tài)增刪示例,可以對(duì)下拉框進(jìn)行刪除和增加,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。
    2017-03-03
  • JS實(shí)現(xiàn)簡(jiǎn)單tab選項(xiàng)卡切換

    JS實(shí)現(xiàn)簡(jiǎn)單tab選項(xiàng)卡切換

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)簡(jiǎn)單tab選項(xiàng)卡切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10

最新評(píng)論