Я достиг этого, изменив исходный код в классах GridRenderer и GridColumn.Изменение в GridColumn заключается в добавлении следующей функции:
public object GetRawValue(T instance)
{
if (!_cellCondition(instance))
{
return null;
}
var value = _columnValueFunc(instance);
return value;
}
Затем изменение в GridRenderer в функции RenderItem будет изменено следующим образом:
protected virtual void RenderItem(GridRowViewData<T> rowData)
{
BaseRenderRowStart(rowData);
HtmlHelper<T> html = new HtmlHelper<T>(Context, new ViewPage());
foreach (var column in VisibleColumns())
{
//A custom item section has been specified - render it and continue to the next iteration.
if (column.CustomItemRenderer != null)
{
column.CustomItemRenderer(new RenderingContext(Writer, Context, _engines), rowData.Item);
continue;
}
RenderStartCell(column, rowData);
var cellValue = column.GetRawValue(rowData.Item);
if (cellValue != null)
{
//RenderText(cellValue.ToString());
MvcHtmlString value = html.DisplayFor<T, object>(m => cellValue);
string str = (value.ToString() == string.Empty) ? cellValue.ToString() : value.ToString();
if (column.HtmlEncode == true)
{
str = (value.ToString() == string.Empty) ? HttpUtility.HtmlEncode(cellValue.ToString()) : value.ToHtmlString();
}
RenderText(str);
}
RenderEndCell();
}
BaseRenderRowEnd(rowData);
}
Как только вы сделаете этоСетка будет использовать найденные шаблоны.Я тестировал только с DisplayTemplates, так как это все, что мне нужно, но оно также должно работать для EditorTemplates с небольшим изменением.