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