我有一个GridView绑定到我构造的DataTable。表中的大多数列包含hypelinklink的原始HTML,我希望HTML在浏览器中呈现为链接,但GridView会自动对HTML进行编码,因此它呈现为标记。
如果不显式添加HyperLink或任何其他列,我该如何避免这种情况?
只需将BoundColumn.HtmlEncode
属性设置为false:
<asp:BoundField DataField="HtmlLink" HtmlEncode="false" />
我担心没有简单的方法可以使用GridView
AutoGenerateColumns
禁用= 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
或使用它的Page
或Control
的类中,自己检查DataTable
并为每列创建一个明确的BoundColumn
:
foreach (DataColumn column in dataTable.Columns)
{
GridViewColumn boundColumn = new BoundColumn
{
DataSource = column.ColumnName,
HeaderText = column.ColumnName,
HtmlEncode = false
};
gridView.Columns.Add(boundColumn);
}
我能够通过使用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);
}
}
}
另一种方法是在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
使用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;
}
}
}
好了,因为链接的html已经在您的数据库中,您可以将html输出到文字控件。
<asp:TemplateField HeaderText="myLink" SortExpression="myLink">
<ItemTemplate>
<asp:Literal ID="litHyperLink" runat="server" Text='<%# Bind("myLink", "{0}") %>' />
</ItemTemplate>
</asp:TemplateField>
这应该将您的链接呈现为原始文本,允许浏览器将其呈现为您期望的链接。
如果要在所有行和列中禁用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;
}
}
}
由于所有答案似乎都在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仍会生成列以及上面添加的列。