チェックボックスグループを検証するための簡単なJavaScriptを書きました。JavaScript は問題なく動作しますが、html で正しく実装するのは難しいことがわかっています。私の試行では、検証に失敗したにもかかわらずフォームが送信されるか、送信ボタンがなくても他のすべてが正常に機能します。誰でも助けることができますか?ありがとう
<form id="form1" name="form1" method="get" action="pre_process.php">
<input name="q" type="text" value="<?php echo $_GET['q']; ?>" size="67"/>
<input type="submit" id="search_button" onclick= "chkChecks()" />
/////this line of code submits the form even when the javascript returns false
<input class="submit" type="button" onclick="chkChecks()" />
///this code works, doesn't send the form, but also takes away my nice shiny submit button
///////js code/////
function chkChecks(){
isChecked=false
for(var i=0;i<document.forms["form1"]["SearchEngines[]"].length;i++){
if(document.forms["form1"]["SearchEngines[]"][i].checked){
isChecked=true
}
}
if(isChecked){
document.forms["form1"].submit()
}
else{
alert('Please select at least one Search Engine')
return false;
}
}
</script>
////また、検証されるフォームの部分
<table width="200">
<tr>
<td><label>
<input type="checkbox" name="SearchEngines[]" value="Bing" id="SearchEngines_0" checked="checked" />
Bing</label></td>
</tr>
<tr>
<td><label>
<input type="checkbox" name="SearchEngines[]" value="Blekko" id="SearchEngines_1" checked="checked" />
Blekko</label></td>
</tr>
<tr>
<td><label>
<input type="checkbox" name="SearchEngines[]" value="Entireweb" id="SearchEngines_2" checked="checked" />
Entireweb</label></td>
</tr>