繁体   English   中英

通过JQuery提交表单时如何点击提交按钮

[英]How to get clicked submit button when submitting a form via JQuery

我有一个带有 2 个提交按钮的表单。

<form class="myForm">
     <!-- Some Inputs Here -->
     <input type="submit" name="firstSubmit" value="first submit" />
     <input type="submit" name="secondSubmit" value="second submit" />
</form>

我正在通过 JQuery 提交此表单。

$(".myForm").submit(function(){
      var submitButton = ? //I need to catch the submit button that was clicked
});

我怎么知道点击了哪个提交按钮?

$('input[type="submit"]').on('click', function(){
      $('.myForm').data('button', this.name);
});

$(".myForm").on('submit', function(){
  var submitButton = $(this).data('button') || $('input[type="submit"]').get(0).name;
});

现在在提交事件中有一个标准的submitter属性。
已经在火狐中实现了!

document.addEventListener('submit',function(e){
    console.log(e.submitter)
})

在 jQuery 中,您只需编写

$(".myForm").on('submit', function(e){
  e.originalEvent.submitter
});

对于不支持它的浏览器,请使用这个 polyfill:

!function(){
    var lastBtn = null
    document.addEventListener('click',function(e){
        if (!e.target.closest) return;
        lastBtn = e.target.closest('button, input[type=submit]');
    }, true);
    document.addEventListener('submit',function(e){
        if (e.submitter) return;
        var canditates = [document.activeElement, lastBtn];
        for (var i=0; i < canditates.length; i++) {
            var candidate = canditates[i];
            if (!candidate) continue;
            if (!candidate.form) continue;
            if (!candidate.matches('button, input[type=button], input[type=image]')) continue;
            e.submitter = candidate;
            return;
        }
        e.submitter = e.target.querySelector('button, input[type=button], input[type=image]')
    }, true);
}();

尝试这个:

$(".myForm").submit(function(){
      var submitButton = $(":focus", this);
});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM