Как визуализировать декодированный HTML в (т.е. <br>) в ячейке GridView - PullRequest
28 голосов
/ 11 января 2009

Я связываю GridView с запросом LINQ. Некоторые поля в объектах, создаваемых оператором LINQ, являются строками и должны содержать новые строки.

Очевидно, GridView HTML-кодирует все в каждой ячейке, поэтому я не могу вставить
для создания новой строки в ячейке.

Как мне сказать GridView не кодировать содержимое ячеек в формате HTML?

Может, мне вместо этого использовать другой элемент управления?

Ответы [ 9 ]

45 голосов
/ 02 апреля 2010

А как насчет установки свойства HtmlEncode на false? Для меня это намного проще.

<asp:BoundField DataField="MyColumn" HtmlEncode="False" />
44 голосов
/ 11 января 2009

Можете ли вы подписаться на событие RowDataBound? Если вы можете, вы можете запустить:

if (e.Row.RowType == DataControlRowType.DataRow)
{
  string decodedText = HttpUtility.HtmlDecode(e.Row.Cells[0].Text);
  e.Row.Cells[0].Text = decodedText;
}
3 голосов
/ 24 февраля 2014
protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
{

    for (int i = 0; i < e.Row.Cells.Count; i++)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            string decodedText = HttpUtility.HtmlDecode(e.Row.Cells[i].Text);
            e.Row.Cells[i].Text = decodedText;
        }
    }
}
3 голосов
/ 11 января 2009

Сохраняются ли нормальные символы новой строки в выходных данных? Если это так, вы можете отправить новые строки и использовать стиль css white-space: pre, который сохранит новые строки, пробелы и символы табуляции.

2 голосов
/ 02 апреля 2010

Ответ Бойзена работает, но только для одного столбца. Если вы запускаете цикл в событии RowDataBound, вы можете заменить переменную на [0] и выполнять эту работу для каждого столбца, если хотите. Вот что я сделал:

protected void gridCart_RowDataBound(object sender, GridViewRowEventArgs e)
{
    for (int i = 1; i < 4; i++)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
            string decode = HttpUtility.HtmlDecode(e.Row.Cells[i].Text);
            e.Row.Cells[i].Text = decode;
        }
    }
}

Мой преднамеренно запущен в 1 из-за моих данных, но, очевидно, он будет работать с тем, что вам нужно.

2 голосов
/ 18 февраля 2010

Я справился с этим, сначала вставив данные в таблицу sql-сервера из многострочного текстового поля, используя

   replace (txt = Replace(txt, vbCrLf,"<br />"))

Затем я использовал решение Рэя Бойзена, чтобы вернуть его в сетку:

 Protected Sub grdHist_RowDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.GridViewRowEventArgs) Handles grdHist.RowDataBound

      Dim col1 As String = HttpUtility.HtmlDecode(e.Row.Cells(2).Text)

      e.Row.Cells(2).Text = col1

End Sub
1 голос
/ 26 сентября 2015
protected void gvHead_OnRowDataBound(object sender, GridViewRowEventArgs e) {
  for (int i = 0; i < e.Row.Cells.Count; i++) 
    e.Row.Cells[i].Text = HttpUtility.HtmlDecode(e.Row.Cells[i].Text);
}
0 голосов
/ 10 сентября 2017

@Ray Booysen ответы верны, но в некоторых случаях HtmlDecode () не может решить вашу проблему. Вы можете использовать UrlDecode () вместо HtmlDecode ().
вот другое решение:

if (e.Row.RowType == DataControlRowType.DataRow)
{
  string decodedText = HttpUtility.UrlDecode(e.Row.Cells[0].Text);
  e.Row.Cells[0].Text = decodedText;
}
0 голосов
/ 18 сентября 2016

Вы должны привязаться к событию DataBoundGrid и изменить рендеринг для столбцов, для которых вы хотите отобразить HTML-код.

public event EventHandler DataBoundGrid {
  add { ctlOverviewGridView.DataBound += value; }
  remove { ctlOverviewGridView.DataBound -= value; }
}

ctlOverview.DataBoundGrid += (sender, args) => {
  ((sender as ASPxGridView).Columns["YourColumnName"] as GridViewDataTextColumn).PropertiesTextEdit.EncodeHtml = false;
};
...