程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> ASP.NET回車提交事件淺析

ASP.NET回車提交事件淺析

編輯:ASP.NET基礎
ASP.NET回車提交事件其實說到底並不是ASP.NET 的編程問題,卻是關於html form 中的submit 按鈕就是如何規劃的具體討論。 也可歸於ASP.NET編程的一部分,那麼ASP.NET回車提交事件的具體實現是怎麼樣的呢?下面我們具體的看下:
ASP.NET回車提交事件實現1、
當你的光標焦點進入某個表單元素的時候,會激活該表單中第一個(流布局順從左到右,從上至下) type=submit 的按鈕(假如有),等待響應回車事件,並提交該form
你可以測試一下代碼:
復制代碼 代碼如下:
﹤form action=""﹥
﹤input type="text" /﹥
﹤input type="submit" value="submit" /﹥
﹤/form﹥
﹤form action=""﹥
﹤input type="text" /﹥
﹤input type="button" value="submit" /﹥
﹤/form﹥

ASP.NET回車提交事件實現2.
在 ASP.NET 2.0 中 button 默認呈現為 ﹤input type=submit﹥ 此時不要額外腳本提交form ,submit 按鈕就是設計用來提交form 而在 1.x 中則呈現為 ﹤input type=button onclick=_doPostBack(...) /﹥ 此普通 button 不具備 submit 的上述默認行為
ASP.NET回車提交事件實現3. 禁用此默認行為有法二
(1)設置 form 元素的 defualtButton 為你希望響應回車的真正按鈕如下
復制代碼 代碼如下:
﹤form id="form1"
runat="server"
defaultbutton="Button1"﹥

注意 defaultButton = ﹤ ﹤TargetButton.ID﹥﹥ 因此這對復合控件中比如模板的 Button 可能無效(未測試)
(2)修改 button 呈現方式 UseSubmitBehavior="false"
復制代碼 代碼如下:
﹤asp:Button ID="Button1"
runat="server" Text="Button"
onclick="Button1_Click"
UseSubmitBehavior="false" /﹥

另外可以通過控制焦點的方式,過濾回車實踐,需要記錄一筆的是,獲取當前頁面焦點所在控件的ID:
document.activeElement
對於ASP.NET.我們在TextBox1中輸入內容後,按下enter鍵後,就執行Button1的click方法。那麼在page_load事件方法中寫。
復制代碼 代碼如下:
TextBox1.Attributes.Add("onkeydown",
"if(event.which || event.keyCode){
if ((event.which == 13) || (event.keyCode == 13)) {
document.getElementById('"+
Button1.UniqueID+"').click();return false;}}
else {return true}; ");

有ASP.NET裡面用了form runat=server的表單的時候,裡面的﹤asp:button .. 總不能按個回車提交表單,很是不爽。
現在終於發現了一個屬性可以干這個事情,用 this.Form.DefaultButton = "ContentPlaceHolder1$btsubmit";
值得注意的是,如果用了masterPage(母板頁),那麼要在按鈕ID前加上母板的ID:ContentPlaceHolderID和一個美元符($)
C#實現代碼如下:
復制代碼 代碼如下:
﹤%@ Page Language="C#"
MasterPageFile="~/MasterPage.master"
AutoEventWireup="true"
CodeFile="login.aspx.cs"
Inherits="login" %﹥
﹤asp:Content ID="Content1"
ContentPlaceHolderID="ContentPlaceHolder1"
Runat="Server"﹥
﹤asp:TextBox runat="server"
ID="wd" ﹥﹤/asp:TextBox﹥
﹤asp:Button ID="btsubmit"
runat="server" Text="提交"
OnClick="btsubmit_Click" /﹥
...........................
﹤/asp:Content﹥

(1)含母板頁的類中:
復制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
this.Form.DefaultButton = "ContentPlaceHolder1$btsubmit";
}

或者在內容頁
復制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
this.Page.Form.DefaultButton = "ContentPlaceHolder1$btsubmit";
}

(2)非母板頁的類中:
復制代碼 代碼如下:
protected void Page_Load(object sender, EventArgs e)
{
this.Form.DefaultButton = "btsubmit";
}

ASP.NET回車提交事件的具體情況就向你介紹到這裡,希望對你了解和學習ASP.NET回車提交事件有所幫助。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved