MvcContrib网格和显示/编辑模板

时间:2010-05-20 20:12:29

标签: asp.net-mvc asp.net-mvc-2 mvccontrib mvccontrib-grid

有没有人遇到过使用./Views/Shared/DisplayTemplates和./Views/Shared/EditTemplates与MvcContrib.UI网格的好解决方案?

我想我可以连接一个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();
%>

网格中可能已经存在某些内容,我还没有找到它。任何帮助将不胜感激。

谢谢,

哈尔

3 个答案:

答案 0 :(得分:3)

我通过修改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并略有改变。

答案 1 :(得分:2)

我创建了这个扩展方法:

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);

答案 2 :(得分:1)

实际上你可以这样做:

column
    .For(model => model.StartDate)
    .Partial("~/Views/Shared/DisplayTemplates/YourModelName.ascx");

这种方法的问题在于整个模型将被传递给部分而不仅仅是属性。