在自动生成的GridView列中阻止HTML编码

问题描述 投票:19回答:7

我有一个GridView绑定到我构造的DataTable。表中的大多数列包含hypelinklink的原始HTML,我希望HTML在浏览器中呈现为链接,但GridView会自动对HTML进行编码,因此它呈现为标记。

如果不显式添加HyperLink或任何其他列,我该如何避免这种情况?

asp.net gridview
7个回答
27
投票

只需将BoundColumn.HtmlEncode属性设置为false:

<asp:BoundField DataField="HtmlLink" HtmlEncode="false" />


我担心没有简单的方法可以使用GridViewAutoGenerateColumns禁用= true中内容的HTML编码。但是,我可以想到两个可能解决您遇到的问题的解决方法:

选项1:在执行基本方法之前,继承GridView类,覆盖Render方法,遍历所有单元格,解码其内容:

for (int i = 0; i < Rows.Count; i++) 
{
    for (int j = 0; j < Rows[i].Cells.Count; j++) 
    {
        string encoded = Rows[i].Cells[j].Text;
        Rows[i].Cells[j].Text = Context.Server.HtmlDecode(encoded);
    }
}

选项2:在继承自GridView或使用它的PageControl的类中,自己检查DataTable并为每列创建一个明确的BoundColumn

foreach (DataColumn column in dataTable.Columns)
{
    GridViewColumn boundColumn = new BoundColumn
        {
            DataSource = column.ColumnName,
            HeaderText = column.ColumnName,
            HtmlEncode = false
        };
    gridView.Columns.Add(boundColumn);
}

9
投票

我能够通过使用JørnSchou-Rode提供的解决方案实现这一点,我进行了一些修改,使其能够从我的Gridview的RowDataBound事件中运行。

protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{
    if (e.Row.RowType == DataControlRowType.DataRow)
    {
           for (int j = 0; j < e.Row.Cells.Count; j++) 
           {
               string encoded = e.Row.Cells[j].Text;
               e.Row.Cells[j].Text = Context.Server.HtmlDecode(encoded);
           }

    }
}

7
投票

另一种方法是在RowDataBound事件处理程序中添加如下内容...

    If e.Row.RowType = DataControlRowType.Header Then
        For Each col As TableCell In e.Row.Cells
            Dim encoded As String = col.Text
            col.Text = Context.Server.HtmlDecode(encoded)
        Next
    End If

3
投票

使用OnRowCreated

    protected void gvFm_RowCreated(object sender, GridViewRowEventArgs e)
    {
        foreach (TableCell cell in e.Row.Cells)
        {
            BoundField fldRef = (BoundField)((DataControlFieldCell)cell).ContainingField;
            switch (fldRef.DataField)
            {
                case "ColToHide":
                    fldRef.Visible = false;                        
                    break;
                case "ColWithoutEncode":
                    fldRef.HtmlEncode = false;                        
                    break;
            }
        }
    }

2
投票

好了,因为链接的html已经在您的数据库中,您可以将html输出到文字控件。

<asp:TemplateField HeaderText="myLink" SortExpression="myLink">
    <ItemTemplate>
        <asp:Literal ID="litHyperLink" runat="server" Text='<%# Bind("myLink", "{0}") %>' />
    </ItemTemplate>
</asp:TemplateField>

这应该将您的链接呈现为原始文本,允许浏览器将其呈现为您期望的链接。


1
投票

如果要在所有行和列中禁用HTML编码,可以在RowDataBound事件中使用此代码。

protected void GV_Product_RowDataBound(object sender, GridViewRowEventArgs e)
{
    if (e.Row.RowType == DataControlRowType.DataRow)
    {
        foreach (TableCell ObjTC in e.Row.Cells)
        {
            string decodedText = HttpUtility.HtmlDecode(ObjTC.Text);
            ObjTC.Text = decodedText;
        }
    }
}

1
投票

由于所有答案似乎都在C#中并且问题不具体,我使用ASP.Net和VB.Net遇到了这个问题,并且接受的解决方案在VB中对我不起作用(尽管我认为它在C#中有效) 。希望这可以帮助任何在ASP中使用VB.Net的人,因为我遇到了这个问题。

在VB.Net中BoundColumn不能添加到Gridview.Columns,因为它不是System.Web.UI.WebControls.DataControlField所以相反,必须使用BoundField这是一个DataControlField

BoundColoumn也没有HtmlEncode财产,但BoundField。此外,在VB.Net DataSource成为DataField

        For Each dataCol As DataColumn In dv.Table.Columns
            Dim boundCol As New BoundField With {
                .DataField = dataCol.ColumnName,
                .HeaderText = dataCol.ColumnName,
                .HtmlEncode = False
            }

            gvResult.Columns.Add(boundCol)
        Next

        gvResult.DataSource = dv
        gvResult.Databind()

另请注意,您必须显式设置AutoGenerateColumns="False",否则GridView仍会生成列以及上面添加的列。

© www.soinside.com 2019 - 2024. All rights reserved.