以下是我为ajax验证所写的代码。我还没有创建表单的提交按钮。问题是,我必须禁用提交按钮,直到所有字段都填充了适当的信息并以ajax方式验证。这只是一个包含两个字段的示例。我有超过20个这样的领域,请帮助我做到这一点。谢谢。使用ajax验证时禁用提交按钮
形式:
<p>
<label for="cname">Name</label>
<em>*</em><input id="cname" name="name" size="50" minlength="2"onkeyup="checkname()"/>
<span id="target1"></span></p>
<p>
<label for="fat">Father's Name</label>
<em>*</em><input id="cfat" name="father" size="50" onkeyup="checkfather()" />
<span id="target2"></span></p>
使用Javascript(AJAX):
var ajax = create_ajax_object();
function checkname(){
if(ajax){
ajax.onreadystatechange = function(){
if(ajax.readyState == 4 && ajax.status == 200){
document.getElementById("target1").innerHTML = ajax.responseText;
}
}
ajax.open("POST", "ajval.php", true);
var values = "name=" + encodeURIComponent(document.commentform.name.value);
values = values + "&action=" + encodeURIComponent("check1");
ajax.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
ajax.send(values);
}
else{
alert("Your browser doesnt support AJAX!");
}
}
function checkfather(){
if(ajax){
ajax.onreadystatechange = function(){
if(ajax.readyState == 4 && ajax.status == 200){
document.getElementById("target2").innerHTML = ajax.responseText;
}
}
ajax.open("POST", "ajval.php", true);
var values = "father=" + encodeURIComponent(document.commentform.father.value);
values = values + "&action=" + encodeURIComponent("check2");
ajax.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
ajax.send(values);
}
else{
alert("Your browser doesnt support AJAX!");
}
}
PHP:
<?php
$action = $_POST["action"];
switch($action)
{
case "check1":
$name=$_POST["name"];
if($name!="")
echo '<img src="green-tick.png" height="20" width="20"/>';
else
echo'<span style="color:red;">Cannot be left blank</span>';
break;
case "check2":
$father=$_POST["father"];
if($father!="")
echo'<img src="green-tick.png" height="20" width="20"/>';
else
echo '<span style="color:red;">Cannot be left blank</span>';
break;
?>
是PHP对这两个字段的完整验证吗?如果是这样,绝对没有理由使用AJAX进行客户端验证; JavaScript不仅能够检查字符串是否为空。 – 2013-03-04 09:45:06
您好@AnthonyGrist我使用带有许多字段的窗体的标签视图,所以点击提交按钮后验证会令人恶心。 – MEP 2013-03-04 09:49:02
点击提交按钮后,我没有说任何关于验证的内容。我正在讨论如何单独验证您的输入,并使用您当前拥有的相同事件处理程序,但如果不需要,则不会使用AJAX进行验证。如果唯一的验证是输入的值不能是空字符串,那么你不需要使用AJAX。 – 2013-03-04 09:51:27