asp.net gridview中的动态链接

本文关键字:动态 链接 net gridview asp | 更新日期: 2023-09-27 18:10:01

我试图创建一个gridview与一个额外的列,其中包含一个超链接的每一行。不幸的是,我的超链接不是从列的顶部开始,而是从超链接列的第二行开始。

查看更多信息>>> https://i.stack.imgur.com/GghBP.png

如图所示,有一个包含超链接的"view"列,但问题是第一行总是空的。第二行上的超链接应该在第一行上,第三行应该在第二行上,以此类推。

谁能告诉我哪里错了?

这是我在aspx页面上的gridview声明:

<asp:GridView ID="GridView1" runat="server" CellPadding="4" AllowPaging="True" 
    AllowSorting="True" AutoGenerateColumns="False" 
    OnPageIndexChanging="GridView1_PageIndexChanging" 
    OnSorting="GridView1_Sorting" PageSize="20" DataKeyNames="no_kwitansi"
    DataSourceID="home1" BackColor="White" BorderColor="#CC9966" BorderStyle="None"
    BorderWidth="1px" RowStyle-Wrap="False" OnRowDataBound="GridView1_RowDataBound">
    <AlternatingRowStyle BackColor="#CCCCCC" />
    <FooterStyle BackColor="#FFFFCC" ForeColor="#330099" />
    <HeaderStyle BackColor="#990000" Font-Bold="True" ForeColor="#FFFFCC" />
    <PagerStyle BackColor="#FFFFCC" ForeColor="#330099" HorizontalAlign="Center" />
    <RowStyle BackColor="White" ForeColor="#330099" />
    <RowStyle HorizontalAlign="Center" />
    <SelectedRowStyle BackColor="#FFCC66" Font-Bold="True" ForeColor="#663399" />
    <SortedAscendingCellStyle BackColor="#FEFCEB" />
    <SortedAscendingHeaderStyle BackColor="#AF0101" />
    <SortedDescendingCellStyle BackColor="#F6F0C0" />
    <SortedDescendingHeaderStyle BackColor="#7E0000" />
    <Columns>
        <asp:BoundField HeaderText="#" />
        <asp:BoundField DataField="no_kwitansi" HeaderText="No.Kwitansi" SortExpression="no_kwitansi" ReadOnly="True" />
        <asp:BoundField DataField="nama_vendor" HeaderText="Vendor" SortExpression="nama_vendor" />
        <asp:BoundField DataField="nama_pekerja" HeaderText="Pekerja" SortExpression="nama_pekerja" />
        <asp:BoundField DataField="nama_penanggungjawab" HeaderText="Penanggungjawab" SortExpression="nama_penanggungjawab" />
        <asp:BoundField DataField="satuan" HeaderText="Satuan" SortExpression="satuan" />
        <asp:BoundField DataField="jumlah" HeaderText="Nominal" SortExpression="jumlah" />
        <asp:BoundField DataField="tanggal" HeaderText="Tanggal" SortExpression="tanggal" />
    </Columns>
</asp:GridView>
下面是我的c#代码:

这是我的page_load函数,我在这里创建了模板字段。

protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {
            ViewState["SortExpr"] = Sort_Direction;
            TemplateField tfield = new TemplateField();
            tfield.HeaderText = "View";
            GridView1.Columns.Add(tfield);
            home1.DataBind();
        }
    }

这是我的gridview rowDataBound函数,在这里我创建了超链接。

protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            HyperLink hlContro = new HyperLink();
            for (int i = 0; i < GridView1.Rows.Count; i++)
            {
                hlContro.NavigateUrl = "./Home.aspx?ID=" + GridView1.Rows[i].Cells[1].Text;
                //hlContro.ImageUrl = "./sample.jpg";
                hlContro.Text = "Documents";
                //GridView1.Rows[i].Cells[0].Controls.Add(hlContro);
            }
            e.Row.Cells[8].Controls.Add(hlContro);
        }
    }

asp.net gridview中的动态链接

那么为什么不只是一个模板字段,并删除所有的服务器端样板呢?如果你改变列的位置会发生什么?

下面是您不需要在服务器端代码中编写任何内容的解决方案。很简单。

<asp:TemplateField HeaderText="Active">
   <ItemTemplate>
     <asp:HyperLink ID="HyperLink1" runat="server" Text='<%# Eval("no_kwitansi") %>' 
        NavigateUrl= '<%# "./Home.aspx?ID=" + Eval("no_kwitansi") %>'>
     </asp:HyperLink>
   </ItemTemplate>
</asp:TemplateField>

当数据行(由GridViewRow对象表示)绑定到GridView控件中的数据时,将引发RowDataBound事件。这使您能够提供一个事件处理方法,该方法可在此事件发生时执行自定义例程,例如修改绑定到该行的数据的值。

就像这样写代码

 protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
        {
            if (e.Row.RowType == DataControlRowType.DataRow)
            {
                HyperLink hlContro = new HyperLink();
                    hlContro.NavigateUrl = "./Home.aspx?ID=" + e.Row.Cells[1].Text;
                    //hlContro.ImageUrl = "./sample.jpg";
                    hlContro.Text = "Documents";
                    //GridView1.Rows[i].Cells[0].Controls.Add(hlContro);
                e.Row.Cells[8].Controls.Add(hlContro);
            }
        }

即使你可以在HTML页面中添加,为什么你要从代码后面添加它

 <asp:TemplateField HeaderText="View">
                <ItemTemplate> 
   <asp:LinkButton ID="test1" runat="server" ForeColor="#525252" Text="Documents" />
                </ItemTemplate>
            </asp:TemplateField>

一个类似的例子显示在这个链接上,您可以尝试 link