首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Javascript表单验证在IE-7,8浏览器中不起作用

Javascript表单验证在IE-7,8浏览器中不起作用
EN

Stack Overflow用户
提问于 2014-03-08 18:24:57
回答 2查看 896关注 0票数 0

我有一个显示汽车比较的网站,我正在做一个表单验证使用javascript,但验证工作正常在Mozila firefox,chrome浏览器,但在IE-7,8它不工作。

代码如下:- JS代码:-

代码语言:javascript
复制
function chk(){
var b1=document.getElementById("txtbrand1").value;
var m1=document.getElementById("txtmodel1").value;
var v1=document.getElementById("txtvariant1").value;
var b2=document.getElementById("txtbrand2").value;
var m2=document.getElementById("txtmodel2").value;
var v2=document.getElementById("txtvariant2").value;


if(b1=='')
{
      document.getElementById('brand1_err').style.display = 'block';
      return false;
}else if(m1=='Car Model'){
    //alert('Please select car 1 model.');
    document.getElementById('model1_err').style.display = 'block';
    return false;
}else if(v1=='Car Variant'){
    //alert('Please select car 1 variant.');
    document.getElementById('variant1_err').style.display = 'block';
    return false;
}else if(b2==''){
    //alert('Please select car 2 brand.');
    document.getElementById('brand2_err').style.display = 'block';
    return false;
}else if(m2=='Car Model'){
    //alert('Please select car 2 model.');
    document.getElementById('model2_err').style.display = 'block';
    return false;
}else if(v2=='Car Variant'){
    //alert('Please select car 2 variant.');
    document.getElementById('variant2_err').style.display = 'block';
    return false;
}else if(b1==b2 && m1==m2 && v1==v2){
    //alert('Please select two different cars.');
    document.getElementById('samecar_err').style.display = 'block';
    return false;
}else{
return true;
}

}

表格代码:-

代码语言:javascript
复制
<form action="admin/pdf/create_result.php" method="post" name="frmcompare" id="frmcompare" onsubmit="return chk();">

表单包含6个字段Car-Name-1、Car-Brand-1、Car-varient-1、Car-Name-2、Car-Brand-2、Car-varient-2。

如果你有任何解决方案,请提前与me.thanks分享。

EN

回答 2

Stack Overflow用户

发布于 2014-03-08 18:41:44

尝试签入按钮的onclick,而不是窗体的onsubmit。像这样的东西

代码语言:javascript
复制
<form action="admin/pdf/create_result.php" method="post" name="frmcompare" id="frmcompare">
  ...
  ...
  <input type="button" name="Compare" value="Compare" onclick="chk();">
</form>
<script>
  function chk(){
    ...
    ...
    document.getElementById("frmcompare").submit();
  }
</script>

如果您更愿意在表单的onsubmit中执行此操作,则必须正确地取消该事件,并支持所有浏览器。尝试将chk()函数中的所有行return false;替换为以下内容:

代码语言:javascript
复制
if(event.preventDefault){
    event.preventDefault();
}else{
   event.returnValue = false;
}
return false;

或者,您可以将此代码放在另一个函数中,假设是CancelSubmit(),并将所有这些return false;行更改为return CancelSubmit();

票数 0
EN

Stack Overflow用户

发布于 2014-03-08 18:44:55

使用长度属性而不是if(b1=='')

代码语言:javascript
复制
if(b1.length===0)

我认为它总是进入第一个,而其他验证在IE中是不起作用的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22268057

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档