submit()和onsubmit()的区别
表单元素拥有submit方法,同时也具有onsubmit事件句柄,用于监听表单提交。可以使用elemForm.submit();方法触发表单提交。
1)、表单元素中出现了name="submit"的元素
这种情况下elemForm.submit();将不会触发表单提交,因为表单原始的submit方法将会被覆盖(formElem.submit就是对该元素的引用)。
2)、elemForm.submit();不会触发表单的onsubmit事件
没有为什么,标准中就是这么规定的。
与此有些类似的是onfocus、onblur和focus()、blur()之间的关系却不同,调用elem.blur()或elem.focus()却会触发onblur和onfocus事件。
这些为我们提供了一个思路,在设计一些UI组件时,需要考虑一些事件在内部调用时是否要触发相关事件。例如Dialog组件,它具有onopen事件,同时返回的对象也会有open()方法,我们这时就必须考虑下open()方法是否需要触发onopen()事件。
====================================================================================================================================
最近在开发中遇到了表单提交前验证的问题,用一个普通的button按钮代替submit按钮,
在提交前触发这个button的onclick事件,在其事件中触发form的submit事件。问题出现了:
以下是出现相关代码:
- <form action="http://www.baidu.com/s?wd=this.form.submit%28%29%3B&cl=3" method="post" name="form1" οnsubmit="return alert('已提交!'); return false;">
- <table align="center" width="420px" cellPadding="2" cellSpacing="1" bgcolor="#A4B6D7" style="word-wrap:Break-word;">
- <tr style="cursor: hand;background:#d7e3f6" >
- <td width="20%" align="right">条型码</td>
- <td><input style="width:90%" type="text" name="GOODSNUM" size="30" maxlength="8" ></td>
- </tr>
- <tr>
- <td align="center" colspan="2">
- <input type="button" name="save" value="保存" οnclick="if((confirm('确定要提交吗?'))) this.form.submit();"/>
- </td>
- </tr>
- </table>
- </form>
2.onsubmit()与submit() :
<html>
<script>
function fun()
{
alert("form_submit");
}
</script>
<form οnsubmit="fun()">
<input type="submit" id="aaa" value="submit"> <!--能弹出form_submit-->
<input type="button" id="bbb" value="onCliCk_submit" οnclick="document.forms[0].submit()">
<!--
表单会提交,但是不会运行fun() 原因是 onsubmit事件不能通过此种方式触发(在IE环境)
直接用脚本doCumetn.formName.submit()提交表单是不会触发表单的onsubmit()事件的
-->
<input type="button" id="bb1" value="onCliCk_onsubmit" οnclick="document.forms[0].onsubmit()"><!--会触发fun()参数,能弹出form_submit-->
</form>
</html>
</form>