IE 一个文本框onkeypress事件的BUG

本文探讨了在Internet Explorer浏览器中不同情况下表单提交事件的触发机制,包括仅有一个文本框、存在提交按钮、多个文本框及按钮等场景,并提供了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,当IE中只有一个文本框,并在文本框上点击“回车”时,表单的submit事件会触发

<form method='post' onsubmit='alert("fm")'>
    <input type='text' value='' id='t1' name='t1'  />
</form>

此时直接激发了form的onsubmit事件,弹出‘fm’提示。

2,当存在submit按钮时:

<form method='post' onsubmit='alert("fm")'>
    <input type='text' value='' id='t1' name='t1'  />
    <input type='button' value='button'/>
    <input type='submit' value='ok' onclick='alert("sumb")'/>
  </form>

效果与1相同。

3,当存在多个文本框时、不存在submit按钮时:

<form method='post' onsubmit='alert("sb")'>
    <input type='text' value='' id='t1' name='t1'  />
    <input type='text' value='' id='t2' name='t2'  />
    <input type='button' value='button'/>
     </form>

此时不会激发onsubmit事件。

4,当存在多个文本框和submit按钮时(submit按钮可以是多个)

<form method='post' onsubmit='alert("sb")'>
    <input type='text' value='' id='t1' name='t1'  />
    <input type='text' value='' id='t2' name='t2'  />
    <input type='button' value='button'/>
    <input type='submit' value='ok' onclick='alert("sumb")'/>
  </form>

此时先激发第一个submit 按钮的onclick事件,再由submit按钮激发onsubmit事件。

5,如果只有一个文本框,也存在submit按钮,并且想让按钮激发回传而不是文本框,可以如下解决:

<HEAD>
 
  <script>
    function zjl()
    {
        var e=window.event;
        if(e.keyCode==13)
        {
            window.location.href='http://www.baidu.com';
            return false;
        }
    }
  </script>
 </HEAD>

 <BODY>
  <form method='post' onsubmit='alert("sb")'>
    <input type='text' value='' id='t1' name='t1' onkeypress='return zjl()' />
    <input type='text' value='' id='t2' name='t2'  />
    <input type='button' value='button'/>
    <input type='submit' value='ok' onclick='alert("sumb")'/>
  </form>
 </BODY>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值