2010-10-22 84 views
0

我有一个带有选择字段A的表单。该字段可以根据URL动态填充,也可以像往常一样选择。验证AJAX生成的表单字段

一旦在字段A中选择了一个值,可以选择字段B并使用JQuery AJAX进行公开。

这是问题所在。如果字段A保持不变,并且由URL动态填充,字段B将正确验证。但是,如果字段A发生更改,字段B将不再尝试验证。

字段A

<select name="FieldA" id="FieldA"> 
<option value="">Please Select</option> 
<?php 
    while($FieldA= mysql_fetch_array($result2)) { 
?> 
<option value="<?php echo $FieldA['FieldAID']; ?>"<?php if ($var == $FieldA['FieldAID']) echo " selected=\"selected\""; ?>><?php echo $FieldA['FieldAName']; ?> </option> 
<?php } ?> 
</select> 

字段B

<select name="FieldB" id="FieldB"> 
<option value="">Please Select</option> 
<?php 
    while($FieldB = mysql_fetch_array($result)) { 
?> 
<option value="<?php echo $FieldB['FieldBID']; ?>"><?php echo str_replace('|',' - ',$FieldB['FieldBName']); ?></option> 
<?php } ?> 
</select> 

验证标准

<script language="JavaScript" type="text/javascript"> 
var frmvalidator = new Validator("FormName"); 
frmvalidator.addValidation("FieldA","req","Please select FieldA."); 
frmvalidator.addValidation("FieldB","req","Please select FieldB."); 
</script> 

一切除了AJAX调用破坏字段B的验证之外。如果字段B没有被重新填充,它可以正常工作。字段B由一个包含文件构建,因此无论是由页面还是AJAX调用填充都是相同的。

谢谢!

+0

所以......你能告诉我们从AJAX调用中获得的确切值吗? – treeface 2010-10-22 21:53:22

+1

你是如何最终解决的? – netadictos 2010-10-29 09:13:24

+0

我还没有解决它。 – 2010-11-01 13:37:14

回答

0

我想你正在使用这个JS库: http://www.javascript-coder.com/html-form/javascript-form-validation.phtml

如果它给你很多问题,也许是时候改变到一个更强大的验证库。

我建议这样的:

http://bassistance.de/jquery-plugins/jquery-plugin-validation/

出现在jQuery的网页,这是非常完整的。语法或多或少是这样的:

$("#signupForm").validate({ 
     rules: { 
      firstname: "required", 
      lastname: "required", 
      username: { 
       required: true, 
       minlength: 2 
      }, 
      password: { 
       required: true, 
       minlength: 5 
      }, 
      confirm_password: { 
       required: true, 
       minlength: 5, 
       equalTo: "#password" 
      }, 
      email: { 
       required: true, 
       email: true 
      }, 
      topic: { 
       required: "#newsletter:checked", 
       minlength: 2 
      }, 
      agree: "required" 
     }, 
     messages: { 
      firstname: "Please enter your firstname", 
      lastname: "Please enter your lastname", 
      username: { 
       required: "Please enter a username", 
       minlength: "Your username must consist of at least 2 characters" 
      }, 
      password: { 
       required: "Please provide a password", 
       minlength: "Your password must be at least 5 characters long" 
      }, 
      confirm_password: { 
       required: "Please provide a password", 
       minlength: "Your password must be at least 5 characters long", 
       equalTo: "Please enter the same password as above" 
      }, 
      email: "Please enter a valid email address", 
      agree: "Please accept our policy" 
     } 
    }); 
+0

我将尝试更新表单以使用JQuery验证,然后报告它是否有效。我有一个同事,虽然有了更新的验证,但他仍然有同样的问题。由AJAX生成的字段不验证,但正确发布信息。谢谢! – 2010-10-26 13:06:46