ASP.NET斷行符號提交事務

來源:互聯網
上載者:User

標籤:style   c   class   blog   code   tar   

淺析ASP.NET斷行符號提交事件[轉]

ASP.NET斷行符號提交事件其實說到底並不是ASP.NET 的編程問題,卻是關於html form 中的submit 按鈕就是如何規劃的具體討論。 也可歸於ASP.NET編程的一部分,那麼ASP.NET斷行符號提交事件的具體實現是怎麼樣的呢?下面我們具體的看下:

ASP.NET斷行符號提交事件實現1、

當你的游標焦點進入某個表單元素的時候,會啟用該表單中第一個(流布局順從左至右,從上至下) type=submit 的按鈕(假如有),等待響應斷行符號事件,並提交該form

你可以測試一下代碼:

  1. ﹤form action=""﹥   
  2. ﹤input type="text" /﹥   
  3. ﹤input type="submit" value="submit" /﹥   
  4. ﹤/form﹥   
  5. ﹤form action=""﹥   
  6. ﹤input type="text" /﹥   
  7. ﹤input type="button" value="submit" /﹥   
  8. ﹤/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 為你希望響應斷行符號的真正按鈕如下

  1. ﹤form id="form1"   
  2.  
  3. runat="server"   
  4.  
  5. defaultbutton="Button1"﹥   

注意 defaultButton = ﹤ ﹤TargetButton.ID﹥﹥ 因此這對複合控制項中比如模板的 Button 可能無效(未測試)

(2)修改 button 呈現方式 UseSubmitBehavior="false"

  1. ﹤asp:Button ID="Button1"   
  2.  
  3. runat="server" Text="Button"   
  4.  
  5. onclick="Button1_Click"   
  6.  
  7. UseSubmitBehavior="false" /﹥   

另外可以通過控制焦點的方式,過濾斷行符號實踐,需要記錄一筆的是,擷取當前頁面焦點所在控制項的ID:

  1. document.activeElement  

對於ASP.NET.我們在TextBox1中輸入內容後,按下enter鍵後,就執行Button1的click方法。那麼在page_load事件方法中寫。

  1. TextBox1.Attributes.Add("onkeydown",   
  2.  
  3. "if(event.which || event.keyCode){  
  4.  
  5. if ((event.which == 13) || (event.keyCode == 13)) {  
  6.  
  7. document.getElementById(‘"+  
  8.  
  9. Button1.UniqueID+"‘).click();return false;}}   
  10.  
  11. else {return true}; ");  

有ASP.NET裡面用了form runat=server的表單的時候,裡面的﹤asp:button .. 總不能按個斷行符號提交表單,很是不爽。
現在終於發現了一個屬性可以幹這個事情,用 this.Form.DefaultButton = "ContentPlaceHolder1$btsubmit";
值得注意的是,如果用了masterPage(母板頁),那麼要在按鈕ID前加上母板的ID:ContentPlaceHolderID和一個美元符($)

C#實現代碼如下:

  1. ﹤%@ Page Language="C#"   
  2. MasterPageFile="~/MasterPage.master"   
  3. AutoEventWireup="true"   
  4. CodeFile="login.aspx.cs"   
  5. Inherits="login" %﹥  
  6. ﹤asp:Content ID="Content1"   
  7. ContentPlaceHolderID="ContentPlaceHolder1"   
  8. Runat="Server"﹥  
  9. ﹤asp:TextBox runat="server"   
  10. ID="wd" ﹥﹤/asp:TextBox﹥  
  11. ﹤asp:Button ID="btsubmit"   
  12. runat="server" Text="提交" 
  13.  OnClick="btsubmit_Click" /﹥  
  14. ...........................  
  15. ﹤/asp:Content﹥ 

(1)含母板頁的類中:

  1. protected void Page_Load(object sender, EventArgs e)  
  2. {  
  3. this.Form.DefaultButton = "ContentPlaceHolder1$btsubmit";  

或者在內容頁

  1. protected void Page_Load(object sender, EventArgs e)  
  2. {  
  3. this.Page.Form.DefaultButton = "ContentPlaceHolder1$btsubmit";  

(2)非母板頁的類中:

  1. protected void Page_Load(object sender, EventArgs e)  
  2. {  
  3. this.Form.DefaultButton = "btsubmit";  

ASP.NET斷行符號提交事件的具體情況就向你介紹到這裡,希望對你瞭解和學習ASP.NET斷行符號提交事件有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.