程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> JSP編程 >> 關於JSP >> JSP中的FORM表單中只有一個input文本時,按回車鍵將會自動提交表單

JSP中的FORM表單中只有一個input文本時,按回車鍵將會自動提交表單

日期:2017/4/17 16:04:35      編輯:關於JSP

一個列表界面只有一個輸入框查詢條件,當首次進入在輸入框中輸入漢字後,按回車鍵發現輸入框中漢字變成亂碼!本以為一個很簡單不過的問題,結果卻花了好久才找到原因(據說是浏覽器問題),按回車後執行了兩次查詢。

1、未修改前代碼:

<form id="ff" name="ff" method="post"> 
  <input type="text" id="userName" name="userName" size="12" maxlength='30' value="${(data.userName)!''}" onKeypress= "javascript:if(event.keyCode==13) do_postAuditList_search();"/> 
</form> 

2、修改後代碼:

<form id="ff" name="ff" method="post"> 
  <input type="text" id="userName" name="userName" size="12" maxlength='30' value="${(data.userName)!''}" onKeypress= "javascript:if(event.keyCode==13) do_postAuditList_search();"/> 
 <!--解決form表單在只有一個input輸入框時回車會自動提交表單--> 
 <input style='display:none' /> 
</form>

即:添加一個<input type='text' style='display:none'/>不顯示輸入框,然後回車之後也不會提交。

補允:

出現自動提交的情況,有兩種可能:

一是編寫了javascript代碼,當用戶點按Enter鍵時,通過js事件偵聽機制觸發表單的提交。

二是利用了浏覽器的默認行為(至少發現ie是這樣的)。浏覽器在解析網頁的時候,有許多默認的行為,例如如果一個頁面上有表單和一個提交按鈕,那麼打開頁面時,焦點會自動落在這個提交按鈕上面。同樣如果一個表單中只有一個單行文本輸入域(text),那麼在這個輸入域中按Enter鍵時,浏覽器會自動提交該表單。

我們對於第一種情況一般都知道而且很容易理解,但是對於第二種浏覽器的默認行為,可能知道這一點的人就比較少了,下面我具體看一下浏覽器(至少ie如此)在表單提交上的默認行為。
如果表單中含有一個單行文本輸入域,那麼無論含有多少其他類型的表單組件,那麼在該輸入域中點擊Enter時,表單會自動提交。例如下面的代碼:

<form action="" method="post">
<input type="text" name="sdfsdf"/>
<textarea></textarea>
<input type="checkbox">sdfsdf
<input type="hidden" name="aa"/>
</form>

如果表單中含有兩個或多個單行文本輸入域,那麼無論是否含有其他類型的表單組件,按Enter鍵時不會自動提交,例如:

<form action="" method="post">
<input type="text" name="sdfsdf"/>
<input type="text" name="sddf"/></form>

辦法很簡單,我們上面舉的例子中已經有了,只要再添加一個文本輸入框就可以了,可能你會說,為了不自動提交就要增加一個沒有用的輸入框,而且中含有兩個輸入框最終用戶會接受嗎?其實可以解決,你可以將那個新添加的輸入框通過style隱藏即可,例如:

<form action="" method="post">
<input type="text" name="notautosubmit" />
<input type="text" name="username"/>
</form>

還有一個方法可以綁定button按鈕 enter觸發事件:

document.onkeypress = function(){
if(event.keyCode == 13) {
search();
return false;
}
}

其中search方法是onclick事件:<form name="searchfrom">

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved