如何在asp.net中的gridview中检索文本框值

时间:2012-11-08 13:15:44

标签: asp.net gridview textbox objectdatasource

这似乎是一个常见问题,但不知怎样,我找到的答案似乎都没有解决我的问题 - 所以想知道我可能会遗漏什么(我是asp.net的新手所以请原谅任何明显的错误)。

我有一个绑定到ObjectDataSource的GridView,它显示纸质杂志及其订阅价格。如果用户希望订阅任何杂志,我想在网格中的每一行添加一个文本框和一个按钮,以允许用户输入日期并单击按钮进行订阅。此文本框的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.

        }
    }
}

1 个答案:

答案 0 :(得分:3)

你几乎拥有它,你在错误的对象上调用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
}