1.
<form class="form" method="post" id="form" onsubmit="return checkForm(this)" action="">
電話號碼:<input id="tel" type="text" maxlength="11" name="tel"/>
<button type="submit" name="submit" value="提交"/>
</form>
function checkForm(o){ var re=/^(13[0-9]{9})|(15[89][0-9]{8})$/; if(!re.test(o.tel.value)){ alert('請輸入正確的手機號碼。'); return false; } }
發生順序:onsubmit -> submit
1.阻止表單提交:
function submitFun(){ //邏輯判斷 return true; //允許表單提交 //邏輯判斷 return false;//不允許表單提交 } <form onsubmit="reture submitFun();"></form> //注意此處不能寫成 onsubmit="submitFun();"否則將表單總是提交
2.
function fun() { alert("form_submit"); }
<form onsubmit="fun()">
<input type="submit" id="aaa" value="submit"> <!--能彈出form_submit-->
<input type="button" id="bbb" value="onCliCk_submit" onCliCk="doCument.forms[0].submit()">
<!--
表單會提交,但是不會執行fun() 原因是 onsubmit事件不能通過此種方式觸發(在IE環境)
直接用指令碼doCumetn.formName.submit()提交表單是不會觸發表單的onsubmit()事件的
-->
<input type="button" id="bb1" value="onCliCk_onsubmit" onCliCk="doCument.forms[0].onsubmit()">
<!--會觸發fun()引數-->
</form>
..