2012-11-08 80 views
2

這似乎是一個常見的問題,但不知何故我發現的答案似乎沒有解決我的情況 - 所以想知道我可能會失蹤(我是新來的asp。所以請諒解任何明顯的錯誤)。如何檢索在asp.net gridview中的文本框的值

我有一個GridView綁定到一個ObjectDataSource,顯示紙質雜誌及其訂閱價格。如果用戶希望訂閱任何雜誌,我想爲網格中的每一行添加一個文本框和一個按鈕,以允許用戶輸入日期並單擊該按鈕進行訂閱。 GridView中沒有字段存在該文本框。

理想情況下,我想向UpdateParameters添加一個參數,以將文本框中的值發送到Update方法。但我一直沒有成功。

我在使用FindControl時發現的一些建議也不起作用。 (我看到在Firefox中使用Inspect Element,生成的控件ID有一個Ctrl0,Ctrl1,Ctrl2前綴。

附加的是示例ASPX頁面和代碼隱藏在這裏的任何見解

提前感謝

這裏的ASPX文件,後面的代碼:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="TestGridView.aspx.cs" Inherits="WebApplication1.TestGridView" %> 

<!DOCTYPE html> 

<html xmlns="http://www.w3.org/1999/xhtml"> 
<head runat="server"> 
    <title></title> 
</head> 
<body> 
    <form id="form1" runat="server"> 
    <div> 
    <asp:GridView ID="GridView1" AutoGenerateColumns="false" runat="server" DatasourceID="ObjectDataSource2" DataKeyNames ="MagazineID" OnRowUpdating="GridView1_RowUpdating"> 
     <Columns> 
      <asp:BoundField DataField="MagazineID" HeaderText ="Magazine ID" ReadOnly="true" SortExpression="PricingID"> 
       <ControlStyle Width="100%" /> 
      </asp:BoundField> 
      <asp:BoundField DataField="MagazineName" HeaderText ="Magazine Name" ReadOnly="true" /> 
      <asp:BoundField DataField="MagazinePrice" HeaderText ="Magazine price" ReadOnly="true" /> 
      <asp:TemplateField HeaderText ="SubscriptionStartDate"> 
       <ItemTemplate> 
        <asp:TextBox ID ="txtSubscriptionStartDateStr" runat="server" Width ="100px"/> 
       </ItemTemplate> 
      </asp:TemplateField> 
      <asp:ButtonField ButtonType="Button" CommandName="Update" Text="Subscribe" /> 
     </Columns> 
    </asp:GridView> 

    <asp:ObjectDataSource ID="ObjectDataSource2" runat="server" UpdateMethod ="AddNewSubscription" SelectMethod="GetAllMagazines" TypeName="WebApplication1.TestGridView"> 
     <UpdateParameters> 
      <asp:ControlParameter ControlID="txtSubscriptionStartDateStr" DefaultValue="" Name="userName" PropertyName="Text" Type="string" /> 
     </UpdateParameters> 
    </asp:ObjectDataSource> 

    </div> 
    </form> 
</body> 
</html> 

代碼隱藏:

using System; 
using System.Collections.Generic; 
using System.Data; 
using System.Linq; 
using System.Web; 
using System.Web.UI; 
using System.Web.UI.WebControls; 

namespace WebApplication1 
{ 
    public partial class TestGridView : System.Web.UI.Page 
    { 
     protected void Page_Load(object sender, EventArgs e) 
     { 

     } 

     public DataTable GetAllMagazines() 
     { 
      DataTable dt = new DataTable(); 

      object[] parms1 = new object[] {11, "Magazine1", 5.99}; 
      object[] parms2 = new object[] {12, "Magazine2", 3.99 }; 

      dt.Columns.Add("MagazineID"); 
      dt.Columns.Add("MagazineName"); 
      dt.Columns.Add("MagazinePrice"); 

      dt.Rows.Add(parms1); 
      dt.Rows.Add(parms2); 

      return dt; 
     } 

     protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e) 
     { 
      GridView gv = (GridView)sender; 
      GridViewRow gvRow = gv.Rows[e.RowIndex]; 
      TextBox tb = (TextBox) gv.FindControl("txtSubscriptionStartDateStr"); 
      if (tb == null) 
       throw new ApplicationException("Could not find TextBox"); 

      string subscriptionStartDateStr = tb.Text; 
      // more code to parse and use the subscription date 
     } 

     public void AddNewSubscription(int magazineID, string subscriptionStartDateStr) 
     { 
      // insert database row here. 

     } 
    } 
} 

回答

2

你幾乎已經擁有它了,你正在對錯誤的對象調用FindControl。

在你GridView1_RowUpdating方法改變:

TextBox tb = (TextBox) gv.FindControl("txtSubscriptionStartDateStr"); 

TextBox tb = (TextBox) gvRow.FindControl("txtSubscriptionStartDateStr"); 

所以你的函數是這樣的:

protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e) 
{ 
    GridView gv = (GridView)sender; 
    GridViewRow gvRow = gv.Rows[e.RowIndex]; 
    TextBox tb = (TextBox) gvRow.FindControl("txtSubscriptionStartDateStr"); 
    if (tb == null) 
    throw new ApplicationException("Could not find TextBox"); 

    string subscriptionStartDateStr = tb.Text; 
    // more code to parse and use the subscription date 
} 
+0

謝謝你的快速反應。這解決了它。 – user1809292

相關問題