jQuery   发布时间:2022-04-19  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了jquery – 当提交按钮被命名为“提交”时,为什么我的表单不提交?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我需要检查表单是否由用户提交,然后在以编程方式提交表单之前执行某些操作.

所以我有这个代码

$('form').submit(function (E) {
    e.originalEvent && e.preventDefault();

     //I change some things in the form here.

    !e.istrigger && $(this).submit();
});

这样可以正常工作,但是当表单提交按钮被命名为“提交”时,它不会.

如果按钮名为“提交”,它甚至可以正常工作. (大写“S”)

我只是好奇为什么会这样?

这是一个demo fiddle

解决方法

你成了一些古老的DOM怪癖的牺牲品.也就是说,DOM中的表单通过各自的名称将所有输入元素(以及按钮)公开为属性

<form>
  <input name="foo">
</form>

结果是:

var form = document.forms[0];
form.foo === document.getElementsByName('foo')[0];

这是不幸的,当你对名称提交有任何控制权时,因为它会影响原始表单的提交方法.

编辑:顺便说一下,为了阅读许多这些陷阱,我建议你看看Kangax’ fantastic DOMLint documentation.

大佬总结

以上是大佬教程为你收集整理的jquery – 当提交按钮被命名为“提交”时,为什么我的表单不提交?全部内容,希望文章能够帮你解决jquery – 当提交按钮被命名为“提交”时,为什么我的表单不提交?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。