检测提交类型(如果是通过输入键或按钮单击)

时间:2013-06-26 20:04:25

标签: javascript html

我有以下代码:

<head>
    <script language="javascript">
        function subimiti(event){
            alert("Tipo do submit: "+event);
        }
    </script>
</head>
<body>
    <form id="f1" name="form1" onsubmit="subimiti(event)" action="http://www.google.com">
        <input type="text" id="meuId" value="Teste"/>
        <input id="butao" type="submit" value="Subimeta u fórmi trem bão!!"/>
    </form>

在我的javascript函数中,我希望我能够检测到导致表单提交的事件,如果是通过单击我的文本字段,或者是通过单击按钮。

1 个答案:

答案 0 :(得分:5)

由于按键事件会在有提交按钮时触发click事件,因此我能想到的唯一解决方法是使用type =按钮。

纯javascript(Fiddle):

<form id="f1" name="form1" action="" onsubmit="subimiti(this)" method="POST">
  <input type="text" id="meuId" value="Test" onkeypress="setEvent(event)"/>
  <input id="butao" type="button" onclick="setEvent(event)" value="Subimeta u formi trem bao!!"/>
</form>

function subimiti(form)
{
  event.preventDefault();
  alert(form.getAttribute('event'));   

}

function setEvent(event)
{
 if(event.type == 'click')
 {
   document.form1.setAttribute('event','click');
   subimiti(document.form1);
 }
 else if (event.keyCode == 13)
 {
   document.form1.setAttribute('event','keypress');
 }
}

使用jQuery(我认为更干净/更简单的代码):

$(function(){
  $('form').submit(function(){
    alert($(this).attr('event'));
  });

  $("input#butao").on('click', function(e) {
    $("form").attr("event", "click").submit();
  });      

  $("input").on('keypress', function(e) {
    if (e.which == 13)
    {
      $("form").attr("event", "keypress");
    }
  });            
}); 

只有针对butao的点击监听器,并输入任何输入的监听器。

<form id="f1" name="form1" action="">
  <input type="text" id="meuId" value="Teste"/>
  <input id="butao" type="button" value="Subimeta u formi trem bao!!"/>
</form>

Fiddle(添加了preventDefault,以便您可以在不实际提交的情况下查看结果)