ホームページ >ウェブフロントエンド >jsチュートリアル >jquery_javascript スキルの validate プラグインと form プラグインの送信方法のまとめ

jquery_javascript スキルの validate プラグインと form プラグインの送信方法のまとめ

WBOY
WBOYオリジナル
2016-05-16 15:07:571410ブラウズ

概要: この記事では主に、フォーム検証および送信ソリューションを実装するために jquery.form と組み合わせた jquery.validate について説明します。

方法 1: jquery.validate の submitHandler オプションを使用する。つまり、フォームが検証に合格したときにコールバック関数が実行されます。このコールバック関数

で jquery.form を介してフォームを送信します。

方法 2: jquery.form の beforeSubmit を使用します。これは、フォームを送信する前に実行されるコールバック関数です。この関数が true を返した場合、フォームは送信されます。 false を返した場合、フォームの送信は終了します。 jquery.validate プラグインの valid() メソッドに従って、jquery.form を通じてフォームを送信するときにフォームを検証できます。

方法 3: jquery.validate を通じてフォームを検証します。この方法の利点は、フォームの検証をより詳細に制御できることです

例: 上記の 3 つの方法を、以下に 3 つの例を通して説明します

CSS スタイル ファイルをロード

コードをコピー コードは次のとおりです:
53f8aada758235eb8931a66ee5ae99ba

CSS スタイル ファイルの内容

input{
 height:25px;
 line-height:25px;
 padding-left:4px;
}

span.checked{
 padding: 0px 5px 0px 25px;
 margin-left: 10px;
 margin-top: 0px;
 margin-bottom: 3px;
 height: 25px;
 line-height:25px;
 font-size: 12px;
 white-space: nowrap;
 text-align: left;
 color: #E6594E;
 background: url("images/acion2.png") no-repeat 3px; /* #FCEAE8 */
}
span.unchecked{
 padding: 0px 5px 0px 25px;
 margin-left: 10px;
 margin-top: 0px;
 margin-bottom: 3px;
 height: 23px;
 line-height:23px;
 font-size: 12px;
 border: 1px solid #E6594E;
 white-space: nowrap;
 text-align: left;
 color: #E6594E;
 background: #FCEAE8 url("images/acion.png") no-repeat 3px;
}

JavaScript ファイルをロード

<script language="JavaScript" type="text/JavaScript" src="js/jQuery1.6.2.js"></script>
<script language="JavaScript" type="text/JavaScript" src="js/jquery.form.js"></script>
<script language="JavaScript" type="text/JavaScript" src="js/jquery.validate.js"></script>
<script language="JavaScript" type="text/JavaScript" src="js/localization/messages_tw.js"></script>

HTML コンテンツ

<body><span id="result"></span>
<form id='commentForm'>
 <fieldset>
 <legend>jquery.validate+jquery.form提交的三种方式</legend>
  <p>
   <label for='cusername'>姓名</label><em>*</em>
   <input id='cusername' name='username' size='25' />
  </p>
  <p>
   <label for='cemail'>电子邮件</label><em>*</em>
   <input id='cemail' name='email' size='25' />
  </p>
  <p>
   <input class='submit' type='submit' value='提交'>
  </p>
 </fieldset>
</form>
</body>

jquery.validate+jquery.form はメソッド 1 の JavaScript コンテンツを送信します

<script language="javascript">
function showResponse(responseText,statusText) {
 if(statusText=='success'){
  $("#result").html(responseText);
 }
}

$(document).ready(function(){
 $('#commentForm').validate({
  focusCleanup:true,focusInvalid:false,
  errorClass: "unchecked",
  validClass: "checked",
  errorElement: "span",
  submitHandler:function(form){
   $(form).ajaxSubmit({
    type:"post",
    url:"test_save.php&#63;time="+ (new Date()).getTime(),
    //beforeSubmit: showRequest,
    success: showResponse
   });
  },
  errorPlacement:function(error,element){
   var s=element.parent().find("span[htmlFor='" + element.attr("id") + "']");
   if(s!=null){
    s.remove();
   }
   error.appendTo(element.parent());
  },
  success: function(label) {
   //label.addClass("valid").text("Ok!")
   label.removeClass("unchecked").addClass("checked");
  },
  rules:{
   username:{required:true,minlength:3},
   email:{
    required:true
   }
  }
 });
});
</script>

jquery.validate+jquery.form はメソッド 2 の JavaScript コンテンツを送信します

<script language="javascript">
function showResponse(responseText,statusText) {
 if(statusText=='success'){
  $("#result").html(responseText);
 }
}

function showRequest(formData,jqForm,options){
 return $("#commentForm").valid();
}

$(document).ready(function(){
 $('#commentForm').submit(function(){
  $(this).ajaxSubmit({
   type:"post",
   url:"test_save.php&#63;time="+ (new Date()).getTime(),
   beforeSubmit:showRequest,
   success:showResponse
  });
  return false; //此处必须返回false,阻止常规的form提交
 });

 $('#commentForm').validate({
  focusCleanup:true,focusInvalid:false,
  errorClass: "unchecked",
  validClass: "checked",
  errorElement: "span",
  errorPlacement:function(error,element){
   var s=element.parent().find("span[htmlFor='" + element.attr("id") + "']");
   if(s!=null){
    s.remove();
   }
   error.appendTo(element.parent());
  },
  success: function(label) {
   //label.addClass("valid").text("Ok!")
   label.removeClass("unchecked").addClass("checked");
  },
  rules:{
   username:{required:true,minlength:3},
   email:{
    required:true
   }
  }
 });
});
</script>

jquery.validate+jquery.form はメソッド 3 の JavaScript コンテンツを送信します

<script language="javascript">
 var options={
  focusCleanup:true,focusInvalid:false,
  errorClass: "unchecked",
  validClass: "checked",
  errorElement: "span",
  errorPlacement:function(error,element){
   var s=element.parent().find("span[htmlFor='" + element.attr("id") + "']");
   if(s!=null){
    s.remove();
   }
   error.appendTo(element.parent());
  },
  success: function(label) {
   //label.addClass("valid").text("Ok!")
   label.removeClass("unchecked").addClass("checked");
  },
  rules:{
   username:{required:true,minlength:3},
   email:{
    required:true
   }
  }
 };

function showResponse(responseText,statusText) {
 if(statusText=='success'){
  $("#result").html(responseText);
 }
}

function showRequest(formData,jqForm,options){
 return $("#commentForm").valid();
}

$(document).ready(function(){
 validator=$('#commentForm').validate(options);
 $("#reset").click(function(){
  validator.resetForm();
 });

 $("button").click(function(){
  validator.form();
 });

 $('#commentForm').submit(function(){
  $(this).ajaxSubmit({
   type:"post",
   url:"test_save.php&#63;time="+ (new Date()).getTime(),
   beforeSubmit:showRequest,
   success:showResponse
  });
  return false; //此处必须返回false,阻止常规的form提交
 });
});
</script>

デモソースコード: ダウンロード

いくつかの質問

1. この問題は、昨夜この記事を書いたときに発見されました。HTML ファイルのヘッダーで 8b05045a5be5764f313ed5b9168a17e6 を使用したときに、入力ボックスのスタイルに問題があったようです。メッセージ。しかし、今日、問題はそれほど単純ではないことがわかりました。8b05045a5be5764f313ed5b9168a17e6 を使用する場合、「名前」入力ボックスでは、最初の文字を入力した後、3 文字に到達するだけで検証に合格したと見なされます。 2文字目まではエラー表示が正常ですが、3文字目を入力するとエラー表示が消え、検証に合格したことを示す「カンマ」の絵が表示されます。ここまでは順調に見えますが、4文字目、5文字目…と文字を入力し続けると問題が発生します。以下に示すように:

100db36a723c770d327fc0aef2ce13b1 の代わりに 8b05045a5be5764f313ed5b9168a17e6 を使用すると、そのような問題は発生せず、すべて正常に動作します。しかし、ここでの疑問は、なぜ 8b05045a5be5764f313ed5b9168a17e6 を追加するとこのような問題が発生するのかということです。さらに、フロントエンドとして 8b05045a5be5764f313ed5b9168a17e6 を追加する必要があります。

この問題に対処するのは非常に複雑です。以下にそのプロセスのリストを示します。そして最後に解決策を示します

まず、昨日エラーメッセージを確認していて、エラーメッセージを挿入しているコードに注目したからです。 errorPlacementにalert(element.parent().html());

という文を追加しました。

errorPlacement:function(error,element){
 alert(element.parent().html());
 var s=element.parent().find("span[htmlFor='" + element.attr("id") + "']");
 if(s!=null){
  s.remove();
 }
 error.appendTo(element.parent());
},

最初の文字を入力すると、下の写真のようなものが表示されます

3 文字を入力します。検証が成功すると、次の画像が表示されます:

さらに文字を入力し続けると、以下に示す結果が得られます

これは次の問題を示しています:

1. 検証が失敗したか成功したかに関係なく、errorPlacement:function(...)

が呼び出されます。

2. s.remove() が機能しません。

この記事を書くときに 8b05045a5be5764f313ed5b9168a17e6 の代わりに 100db36a723c770d327fc0aef2ce13b1 を使用したため、次の図に示すように、ポップアップ コンテンツは for="cusername" ではなく htmlFor="cusername" になります。 🎜>

したがって、上記のコードは次のように記述されます

 var s=element.parent().find("span[htmlFor='" + element.attr("id") + "']");
 if(s!=null){
  s.remove();
 }
ただし、8b05045a5be5764f313ed5b9168a17e6 では、ddef4b7cd4689d0697b170046264242a54bdf357c58b8a65c66d7c19c8e4d114 が htmlFor に基づいて見つからないため、ここで htmlFor を for に変更する必要があります。それは、

errorPlacement:function(error,element){
 alert(element.parent().html());
 var s=element.parent().find("span[for='" + element.attr("id") + "']");
 if(s!=null){
  s.remove();
 }
 error.appendTo(element.parent());
},

问题似乎解决了。但上面提到,不管验证成功或失败,都会调用errorPlacement:function(...),那可以在这里判断有没有错误,如果有错误,则显示。防止已经验证成功的情况下仍会调用。这样就不会寻找span的for属性值是否为当前控件的name名称了(例子中是for="cusername")。改进的代码如下:

errorPlacement:function(error,element){
 if(error.html()!=''){
  error.appendTo(element.parent());
 }
},

虽然解决问题,但是在chrome、firefox下仍有问题。了解这个问题的现象,可以用firefox或chrome测试一下——焦点离开输入框后,无法验证,只有点击“提交”按钮后才可以验证——这个问题的解决方案目前还没有深入下去。但是有解决的办法是,将上面的jquery1.6.2换成jquery1.3.2或jquery1.4(其它的jquery版本未测试,可能是低于jquery1.6.2的版本都可以)即可解决这个问题。

建议:

1、使用jquery1.3.2版本,这样可以节省很多时间来解决兼容方面的问题。

更多:

本例子中的jquery.validate,解决了remote远程验证只返回true or false的局限。可以返回代码及出错的提示信息,更好的人性化需求。使用方法就在这介绍一下

增加以下函数

function GetRemoteInfo(postUrl,data){
 var remote = {
  type: "POST",
  async: false,
  url: postUrl,
  dataType: "xml",
  data: data,
  dataFilter: function(dataXML) {
   var result = new Object();
   result.Result = jQuery(dataXML).find("Result").text();
   result.Msg = jQuery(dataXML).find("Msg").text();
   //alert(result.Result);
   if (result.Result == "-1") {
    result.Result = false;
    return result;
   }else{
    result.Result = result.Result == "1" &#63; true : false;
    return result;
   }
  }
 };
 return remote;
}

$(document).ready(function(){
 var dataInfo ={email:function(){return $("#cemail").val();}};
 var remoteInfo = GetRemoteInfo('check-email.php&#63;time='+(new Date()).getTime(),dataInfo);
 $('#commentForm').validate({
  rules:{
   username:{
    required:true,
    minlength:3
   },
   email:{
    required:true,
    remote:remoteInfo
   }
  }
 });
 ....
});

check-email.php返回的内容为xml格式,格式如下

<&#63;php
header("Content-Type:text/xml");
echo '<&#63;'.'xml version="1.0" encoding="utf-8"'.' &#63;>';
&#63;>
<AjaxClass>
<Msg>用户名格式不正确,用户名必须包含testa,请重新输入!</Msg>
<Result>0</Result>
</AjaxClass>

result值为0,返回的是false,表示验证失败;result值为1,返回的是true,表示验证成功

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。