使用c#将数据从gridview传输到asp.net中的另一个webform?

时间:2012-11-06 09:44:34

标签: c# asp.net gridview datagridview

我有这样的网格视图:

 <asp:GridView ID="wbsdataGV1" runat="server" Width="790px" AutoGenerateColumns="False"
                                    OnSelectedIndexChanged="wbsdataGV1_SelectionChanged">
                                    <Columns>

                                        <asp:TemplateField HeaderText="WBS Code">
                                            <ItemTemplate>
                                                <asp:LinkButton ID="LinkButton1" runat="server" Text='<%# Eval("WBSCode") %>'></asp:LinkButton>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="Description">
                                            <ItemTemplate>
                                                <asp:TextBox ID="TextBox7" runat="server" Text='<%# Eval("Description") %>'></asp:TextBox>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="Territory Code">
                                            <ItemTemplate>
                                                <asp:TextBox ID="TextBox8" runat="server" Text='<%# Eval("TerritoryCode") %>'></asp:TextBox>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                        <asp:TemplateField HeaderText="Amount">
                                            <ItemTemplate>
                                                <asp:TextBox ID="TextBox9" runat="server" Text='<%# Eval("AmountReleased") %>'></asp:TextBox>
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                    </Columns>
                                </asp:GridView>

当我点击链接按钮时,我想要那些数据,我将把它转移到另一个aspx来自..通过

protected void wbsdataGV1_SelectionChanged(object sender, EventArgs e)
{
    //Some code ;
}

现在我的问题是我如何通过点击gridview上的链接按钮来获取数据?我可以通过查询字符串或会话变量或隐藏文本字段传输数据......但我担心的是如何获得确切的点击数据... 任何帮助?

1 个答案:

答案 0 :(得分:1)

将DataKeys属性定义为数据的主键(这里我假设您有一个名为“ID”的行标识符。

<asp:GridView ... DataKeys="ID">
    ... existing markup
</asp:GridView>

wbsdataGV1_SelectionChanged中,取回用户点击的行的ID,如下所示:

int rowID = (int)this.wbsdataGV1.SelectedDataKey.Value;

然后重定向到这样的另一个页面,只传递ID:

Response.Redirect("anotherpage.aspx?id=" + rowID);

然后在你的另一页:

protected void Page_Load(object s, EventArgs e)
{
    if (!Page.IsPostback)
    {
        int rowID = int.Parse(Request.QueryString["id"]);

        // do something with the ID of the row, like go and look
        // up JUST that row again
    }
}

奖励 - 要使整行可以点击,避免使用CommandButton,请执行以下操作:

<script language="javascript" type="text/javascript">
    var oldColour = null;

    function rowMouseover(o) {
        o.style.cursor = 'pointer';
        oldColour = o.style.backgroundColor;
        o.style.backgroundColor = '#dddddd';
    }

    function rowMouseout(o) {
        o.style.backgroundColor = oldColour;
    }
</script>

<asp:GridView ... OnRowCreated="grid_RowCreated" />

protected void grid_RowCreated(object sender, GridViewRowEventArgs e)
{
    if (e.Row.RowType == DataControlRowType.DataRow)
    {
        e.Row.Attributes["onclick"] =
            Page.ClientScript.GetPostBackClientHyperlink(
                this.grid, 
                "Select$" + e.Row.RowIndex);

        e.Row.Attributes["onmouseover"] = "rowMouseover(this);";
        e.Row.Attributes["onmouseout"] = "rowMouseout(this);";
    }
}

protected override void Render(HtmlTextWriter writer)
{
    for (int i = 0; i < grid.Rows.Count; i++)
        Page.ClientScript.RegisterForEventValidation(grid.UniqueID, "Select$" + i); 

    base.Render(writer);
}

你可以通过Session对象传递ID,但是你会得到奇怪的行为,同时有多个浏览器窗口同时执行相同的操作(取决于浏览器)。这对用户来说很难篡改。

您也可以通过Request.Form传递ID,这会将其隐藏起来,但不会添加任何真正的安全性。

Protip:不要只是将大量对象转储到Session变量中。它很懒惰,容​​易出错,而且无法扩展。