Textbox控件注冊回車事件及觸發(fā)按鈕提交事件具體實現(xiàn)
更新時間:2013年03月04日 15:09:30 作者:
Lyncplus客戶端中訪問Web頁面時遇到了TextBox控件回車自動完成按鈕的提交事件失效的情況,于是上網(wǎng)查找相關(guān)的介紹最終解決了這兩個問題,感興趣的你可以參考下或許對你有所幫助
引子:
在ASP.Net頁面中textbox的index為1(或n),其后的提交按鈕index為2(n+1),光標在textbox中,回車后自動焦點移動到后面的button上,會觸發(fā)button的點擊事件。
但在Lyncplus客戶端中訪問Web頁面時遇到了TextBox控件回車自動完成按鈕的提交事件失效的情況(應(yīng)該是自動切換焦點)。
由于并且該服務(wù)端TextBox控件沒有提供OnKeyPress或OnKeyDown等事件,也無法針對回車事件寫后臺代碼來調(diào)用Button按鈕的點擊事件。
于是上網(wǎng)查找相關(guān)的介紹,最終解決了以下兩個問題:
(一)、實現(xiàn)在TextBox控件回車事件中 執(zhí)行JS代碼,來控制頁面元素的值。
(二)、實現(xiàn)在TextBox控件回車事件中 調(diào)用服務(wù)端控件的點擊事件,來執(zhí)行服務(wù)端C#代碼,實現(xiàn)相關(guān)的功能。
具體實現(xiàn)如下:
一、注冊和觸發(fā)服務(wù)端TextBox控件回車事件
1.PageLoad事件代碼:
protected void Page_Load(object sender, EventArgs e)
{
MessageTxt.Attributes.Add("onkeypress", "EnterTextBox()");
MessageTxt.Attributes.Add("onkeydown", "EnterTextBox()");
}
2.javascript代碼:
<script language="javascript">
function EnterTextBox() {
if (event.keyCode == 13 && document.all["MessageTxt"].value != "") //按下了回車,并且文本框里有值
{
$("#<%=hidKeywords.ClientID%>").val($("#<%=MessageTxt.ClientID%>").val().replace(/[^\u0000-\u00FF]/g,
function ($0) {
return escape($0).replace(/(%u)(\w{4})/gi, "&#x$2;")
}));
}
}
</script>
二、TextBox控件回車事件中調(diào)用服務(wù)端Button控件點擊事件
1.PageLoad事件代碼: 同上。
protected void Page_Load(object sender, EventArgs e)
{
MessageTxt.Attributes.Add("onkeypress", "EnterTextBox()");
MessageTxt.Attributes.Add("onkeydown", "EnterTextBox()");
}
2.javascript代碼: 注意使用原始的dom對象獲取按鈕,使用Jquery獲取不到。
<script language="javascript">
function EnterTextBox() {
var button = document.getElementById('<%=btnSearch.ClientID%>');//獲取服務(wù)端控件對應(yīng)的頁面對象
if (event.keyCode == 13) //按下了回車
{
button.click();
event.returnValue = false;
}
} </script>
在ASP.Net頁面中textbox的index為1(或n),其后的提交按鈕index為2(n+1),光標在textbox中,回車后自動焦點移動到后面的button上,會觸發(fā)button的點擊事件。
但在Lyncplus客戶端中訪問Web頁面時遇到了TextBox控件回車自動完成按鈕的提交事件失效的情況(應(yīng)該是自動切換焦點)。
由于并且該服務(wù)端TextBox控件沒有提供OnKeyPress或OnKeyDown等事件,也無法針對回車事件寫后臺代碼來調(diào)用Button按鈕的點擊事件。
于是上網(wǎng)查找相關(guān)的介紹,最終解決了以下兩個問題:
(一)、實現(xiàn)在TextBox控件回車事件中 執(zhí)行JS代碼,來控制頁面元素的值。
(二)、實現(xiàn)在TextBox控件回車事件中 調(diào)用服務(wù)端控件的點擊事件,來執(zhí)行服務(wù)端C#代碼,實現(xiàn)相關(guān)的功能。
具體實現(xiàn)如下:
一、注冊和觸發(fā)服務(wù)端TextBox控件回車事件
1.PageLoad事件代碼:
復制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
MessageTxt.Attributes.Add("onkeypress", "EnterTextBox()");
MessageTxt.Attributes.Add("onkeydown", "EnterTextBox()");
}
2.javascript代碼:
復制代碼 代碼如下:
<script language="javascript">
function EnterTextBox() {
if (event.keyCode == 13 && document.all["MessageTxt"].value != "") //按下了回車,并且文本框里有值
{
$("#<%=hidKeywords.ClientID%>").val($("#<%=MessageTxt.ClientID%>").val().replace(/[^\u0000-\u00FF]/g,
function ($0) {
return escape($0).replace(/(%u)(\w{4})/gi, "&#x$2;")
}));
}
}
</script>
二、TextBox控件回車事件中調(diào)用服務(wù)端Button控件點擊事件
1.PageLoad事件代碼: 同上。
復制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
MessageTxt.Attributes.Add("onkeypress", "EnterTextBox()");
MessageTxt.Attributes.Add("onkeydown", "EnterTextBox()");
}
2.javascript代碼: 注意使用原始的dom對象獲取按鈕,使用Jquery獲取不到。
復制代碼 代碼如下:
<script language="javascript">
function EnterTextBox() {
var button = document.getElementById('<%=btnSearch.ClientID%>');//獲取服務(wù)端控件對應(yīng)的頁面對象
if (event.keyCode == 13) //按下了回車
{
button.click();
event.returnValue = false;
}
} </script>
相關(guān)文章
javascript+css3 實現(xiàn)動態(tài)按鈕菜單特效
這篇文章主要介紹了javascript+css3 實現(xiàn)動態(tài)按鈕菜單特效的相關(guān)資料,需要的朋友可以參考下2016-02-02小程序使用webview內(nèi)嵌h5頁面 wx.miniProgram.getEnv失效問題
本文主要介紹了小程序使用webview內(nèi)嵌h5頁面 wx.miniProgram.getEnv失效問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-04-04