日期:2014-05-16 浏览次数:20406 次
1. 在表单(form)中,如果以标签<input type="submit"/>作为表单提交的触发方式,那么在浏览器提交网页之前,会触发表单(form)的onsubmit事件。这样只要在表单(form)的onsubmit属性中加入代码即可完成表单提交事件的捕捉和处理。
?
<html> <body> <form action="." method="GET" onsubmit="alert('catch and do something')"> <input type="submit"/> </form> </body> </html>
点击提交按钮后,会有弹出框显示。?
?
2. 如果表单的提交方式是直接调用表单的sumbit方法,那么表单的onsubmit方法将不会被触发。这样第1点所述的捕捉方法就会失效。
?
<html> <body> <form id="form1" action="." method="GET" onsubmit="alert('catch and do something')"> <input type="button" value="提交查询" onclick="form1.submit();"/> </form> </body> </html>
点击提交按钮后,不会有弹出框显示。
?
解决办法:?劫持表单的submit属性,使其指向自定义函数,在这个函数中手动调用表单的onsubmit方法以及原先指向的那个submit方法。
?
<html> <body> <form id="form1" action="." method="GET" onsubmit="alert('catch and do something')"> <input type="button" value="提交查询" onclick="form1.submit();"/> </form> <script> var func = document.forms[0].submit; document.forms[0].submit=function(){ if(this.onsubmit() != false) func.apply(this); // IE8 如果是IE6,7改为 func(); } </script> </body> </html>
?
* 以上代码样例仅为配合解释事件捕捉及处理的原理,并非最优。在引用上述样例代码时,根据具体的情况,可能需要做一些改动才能使其正常运转。