我正在使用具有多个提交按钮的ASP.NET MVC网站.即
我需要允许用户通过按"Enter"键快速提交表单.HTML标准似乎指定如果用户按下"Enter"键,将假定第一个提交按钮.但是,我需要将第二个按钮(即"确定")按钮设为默认按钮,并且由于我甚至不想谈论的原因,更改按钮顺序不是一个选项.
我google了一下,我发现这篇文章关于在ASP.NET中使用Page.Form.DefaultButton,但这不适用于ASP.NET MVC.
我也尝试了以下javascript解决方案,虽然它可以在Chrome中运行但在IE6中不起作用
$('body').keypress(function(e) { if (e.which === 13) { $("input[value='OK']").trigger('click'); } });
我可以想到一些非常极端的解决方案,例如遍历表单中的每个控件,将上述函数附加到它们上面.但是,我不认为这是一个非常简洁的解决方案,所以我想知道有没有人有更好的解决方案?
首先,这是错误的:
所有这三个都是提交按钮.复位是type ="reset"的输入.得到那个排序.其次,我已经成功实现了类似的东西,它适用于IE6.试试这个:
function keypressHandler(e) { if(e.which == 13) { e.preventDefault(); //stops default action: submitting form $(this).blur(); $('#SubmitButton').focus().click();//give your submit an ID } } $('#myForm').keypress(keypressHandler);
当用户按下回车键时,focus()部分会使按钮显示为按下.相当漂亮.
用这个.
$(function(){ $('input').keydown(function(e){ if (e.keyCode == 13) { $("input[value='OK']").focus().click(); return false; } }); });