10

我正在尝试创建一个具有网格视图的网页。这个gridview应该有一个如下的链接

http://localhost/Test.aspx?code=123

当用户在 gridview 中单击某一行的链接时,它将打开一个空白页面并显示一些结果。

这是我如何将数据绑定到gridview,但我不知道如何设置链接

protected void Page_Load(object sender, EventArgs e)
{
    string firma_no = logoFrmNr.ToString().PadLeft(3, '0');
    string active_period = logoFrmPeriod.PadLeft(2, '0');

    SqlConnection conn = new SqlConnection(conStr);
    string selectSql = @"SELECT 
                                LOGICALREF,
                                CODE , 
                                DEFINITION_ ,
                                FROM 
                                LG_CLFLINE";

    SqlCommand cmd = new SqlCommand(selectSql, conn);
    DataTable dt = new DataTable();
    SqlDataAdapter da = new SqlDataAdapter(cmd);
    da.Fill(dt);
    GridView1.DataSource = dt;
    GridView1.DataBind();

    conn.Close();
}

这是标记

<asp:GridView ID="GridView1" runat="server" EnableModelValidation="True">
</asp:GridView>

如何从 CODE 列中建立链接?

4

4 回答 4

10

这有一个窍门。超链接列不起作用,因为您无法格式化链接。您想使用绑定字段并格式化文本。像这样

<asp:GridView ID="GridView1" runat="server" EnableModelValidation="True">
    <Columns>
        <asp:BoundField DataField="Code" HtmlEncode="False" DataFormatString="<a target='_blank' href='Test.aspx?code={0}'>Link Text Goes here</a>" />
    </Columns>
</asp:GridView>

或者,如果您需要指定编辑和插入模板,您可以使用模板字段。

于 2013-11-05T20:58:39.633 回答
10

将此添加到您Columns的网格视图标记中的定义中:

<asp:TemplateField HeaderText="Hyperlink">
    <ItemTemplate>
        <asp:HyperLink ID="HyperLink1" runat="server" 
            NavigateUrl='<%# Eval("CODE", @"http://localhost/Test.aspx?code={0}") %>' 
            Text='link to code'>
        </asp:HyperLink>
    </ItemTemplate>
</asp:TemplateField>
于 2013-11-05T21:00:43.880 回答
3

对我来说,这就像

<asp:DataGrid id="MyDataGrid" 
           GridLines="Both"
           AutoGenerateColumns="false"
           runat="server">

         <HeaderStyle BackColor="#aaaadd"/>

         <Columns>

            <asp:HyperLinkColumn
                 HeaderText="Select an Item"
                 DataNavigateUrlField="code"
                 DataNavigateUrlFormatString="http://localhost/Test.aspx?code={0}"
                 Target="_blank"/>

         </Columns>

      </asp:DataGrid>
于 2013-11-05T21:06:11.220 回答
2

您应该能够在标记中使用 HyperLinkColumn。

超链接列文档

于 2013-11-05T20:52:49.457 回答