1、當(dāng)form表單中只有一個(gè)<input type="text" name="name" />時(shí)按回車鍵將會(huì)自動(dòng)將表單提交。
代碼如下:
<form id="form1" action="post.php" method="post">
<input type="text" name="name" />
</form>
再添加一個(gè)
代碼如下:
<input type="text" />
按下回車將不會(huì)自動(dòng)提交,但是頁(yè)面上顯示一個(gè)不知所云的輸入框挺別扭,后從網(wǎng)上搜到兩個(gè)解決辦法:
(1)添加一個(gè)
代碼如下:
<input style="display: none;" type="text" />
不顯示輸入框,然后回車之后也不會(huì)提交:
代碼如下:
<form id="form1" action="post.php" method="post">
<input type="text" name="name" />
<input style="display:none" />
</form>
(2)添加一個(gè)onkeydown事件,然后回車之后也不會(huì)顯示:
代碼如下:
<form id="form1" action="post.php" method="post">
<input type="text" name="name" onkeydown="if(event.keyCode==13) return false;"/>
</form>
如果想添加回車事件可以在onkeydown事件中添加判斷提交表單:
代碼如下:
<form id="form1" action="post.php" method="post">
<input style="display:none" />
<input type="text" name="name" onkeydown="if(event.keyCode==13){gosubmit();}" />
</form>
我們有時(shí)候希望回車鍵敲在文本框(input element)里來(lái)提交表單(form),但有時(shí)候又不希望如此。比如搜索行為,希望輸入完關(guān)鍵詞之后直接按回車鍵立即提交表單,而有些復(fù)雜表單,可能要避免回車鍵誤操作在未完成表單填寫的時(shí)候就觸發(fā)了表單提交。
要控制這些行為,不需要借助JS,瀏覽器已經(jīng)幫我們做了這些處理,這里總結(jié)幾條規(guī)則:
如果表單里有一個(gè)type="submit"的按鈕,回車鍵生效。
如果表單里只有一個(gè)type="text"的input,不管按鈕是什么type,回車鍵生效。
如果按鈕不是用input,而是用button,并且沒(méi)有加type,IE下默認(rèn)為type=button,F(xiàn)X默認(rèn)為type=submit。
其他表單元素如textarea、select不影響,radio checkbox不影響觸發(fā)規(guī)則,但本身在FX下會(huì)響應(yīng)回車鍵,在IE下不響應(yīng)。
type="image"的input,效果等同于type="submit",不知道為什么會(huì)設(shè)計(jì)這樣一種type,不推薦使用,應(yīng)該用CSS添加背景圖合適些。
更多信息請(qǐng)查看IT技術(shù)專欄