这似乎是一个常见问题,但不知何故,我找到的答案似乎都无法解决我的问题 - 所以想知道我可能会错过什么(我是 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.
}
}
}