MVCCONTRIBグリッドと表示/編集テンプレート
-
04-10-2019 - |
質問
mvccontrib.uiグリッドを使用して、./views/shared/displaytemplatesと./views/shared/edittemplatesを使用するための良いソリューションに出くわしましたか?
私はcustomitemrendererをワイヤーアップできると思いますが、私はむしろ次のようなことをすることができます。
<% Html.Grid<Person>(Model.People)
.Sort(new GridSortOptions {Column = Model.Column, Direction = Model.Direction})
.Columns(column =>
{
column.For(e=>e.Name);
column.DisplayFor(e=>e.StartDate); // <-- I'd like to do this for DateTime.asxc
}).Render();
%>
これを行うためにすでにグリッドに何かがあるかもしれませんが、私はまだそれを見つけていません。どんな助けも大歓迎です。
ありがとう、
ハル
解決
グリッドレンダーとグリッドコラムクラスのソースコードを変更することで、これを経験しました。グリッドコラムの変更は、次の関数を追加することです。
public object GetRawValue(T instance)
{
if (!_cellCondition(instance))
{
return null;
}
var value = _columnValueFunc(instance);
return value;
}
次に、グリッドレンダーの変更は、次のように変更されるようになります。
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でのみテストしましたが、わずかな変更で編集された編集でも機能するはずです。
他のヒント
この拡張法を作成しました。
public static IGridColumn<Column> DisplayFor<Column, Model, Value>(this ColumnBuilder<Column> column, HtmlHelper<Model> html, Func<Column, Value> getValueFunc)
where Column : class
{
return column.Custom(o =>
{
var value = getValueFunc(o);
return MvcHtmlString.Create("<span>" + html.DisplayFor(modelItem => value) + "</span>");
});
}
使用法は次のように見えます:
column.DisplayFor(Html, sector => sector.Created);
実際にこれを行うことができます:
column
.For(model => model.StartDate)
.Partial("~/Views/Shared/DisplayTemplates/YourModelName.ascx");
このアプローチの問題は、モデル全体が単なるプロパティではなく、部分的に渡されることです。
所属していません StackOverflow