通过在 ASP.net MVC 2 应用程序中传递数据表,使用 mvccontrib 自动生成网格

发布于 2024-09-08 14:54:32 字数 1143 浏览 6 评论 0原文

在我的项目中,我想使用 mvccontrib (http://mvccontrib.codeplex.com) 自动生成网格通过将数据表传递到网格。目前 Grid 不支持此功能。

网格采用 IEnumerable(Of T) 并自动生成列。他们有什么办法可以通过传递 DataTable 来实现这一点吗?或者我如何将 DataTable 转换为 IEnumerable(Of T)。我的数据表是完全动态的,我在设计时不知道列数或列名称。 DataTable完全动态,列数不固定,它只是任何DataTable。

我怎样才能做到这一点?

简而言之,我想将 Dynamic DataTable 转换为 IEnumerable(Of T)。或者他们有更好的方法吗?

我尝试了以下方法

1)我尝试的一种方法是使用 .net 4.0 Dynamic、DynamicObject 和 ExpandoObject 我创建了一个动态类,如下所示 http:// msdn.microsoft.com/en-us/library/system.dynamic.dynamicobject.trygetindex.aspx。我尝试传递 IEnumerable(Of SampleDynamicObject) 但 BuildColumns() 方法无法找出动态添加到其上的属性。

2)我认为修改 AutoGenerateColumns() 方法以与 DataTable 一起使用的第二种方法,但看起来不可能,因为 Grid Get 使用 IEnumerable(Of T) 进行初始化,并且对网格方法的所有调用都使用 IEnumerable(Of T)。所以归结为将 DataTable 转换为 IEnumerable(Of T) 并且我的 DataTable 是动态的我在设计时不知道它们的结构所以我无法编写任何特定的类来创建对象并将 DataTable 转换为 IEnumerable(Of T) 。

大家有没有更好的办法解决这个问题。

谢谢桑迪

In My project i want to use the mvccontrib (http://mvccontrib.codeplex.com) to auto generate grid by passing the DataTable to the Grid. Currently Grid does not support this.

Grid takes IEnumerable(Of T) and auto generate columns. Is their any way i can achieve this by passing DataTable. Or How do i convert the DataTable to IEnumerable(Of T). My DataTable is completely Dynamic i don't know number of columns or names of the columns at design time. DataTable completely dynamic number of columns are not fixed it just any DataTable.

How can i achieve this?

In Short i want to convert Dynamic DataTable to IEnumerable(Of T). Or Is their any better way.

I tried following way

1) One way i tried is using .net 4.0 Dynamic, DynamicObject and ExpandoObject
I created a dynamic class as shown here http://msdn.microsoft.com/en-us/library/system.dynamic.dynamicobject.trygetindex.aspx. I trid passing IEnumerable(Of SampleDynamicObject) but BuildColumns() method is not able to find out the proprieties dynamically added on to it.

2) I think Second way to modify the AutoGenerateColumns() method to work with DataTable, But it looks impossible as Grid Get initialize using IEnumerable(Of T) and all the call on grid for method is using IEnumerable(Of T). So it's come down to converting DataTable to IEnumerable(Of T) and my DataTable are dynamic i don't know their structure at design time So i can't write any specific class to create a object and convert DataTable to IEnumerable(Of T).

Does any one have any better way out on this.

Thanks

Sandy

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

夜司空 2024-09-15 14:54:32

这个问题很老了,但也许这可以帮助其他人。我只需要用动态 DataTable 填充网格,然后在视图中这样做:

Index.cshtml

@using System.Data
@using MvcContrib.UI.Grid
@model SomeDataTable

@Html.Grid(Model.Rows.Cast<DataRow>()).Columns(columns =>{
  foreach (var dataColumn in Model.Columns.Cast<DataColumn>()){
    var column = dataColumn;
    columns.For(x => x[column]).Named(column.Caption);
  }
})

The question is quite old but maybe this could help someone else. I just needed to fill grid with dynamic DataTable and I do it like this in view:

Index.cshtml

@using System.Data
@using MvcContrib.UI.Grid
@model SomeDataTable

@Html.Grid(Model.Rows.Cast<DataRow>()).Columns(columns =>{
  foreach (var dataColumn in Model.Columns.Cast<DataColumn>()){
    var column = dataColumn;
    columns.For(x => x[column]).Named(column.Caption);
  }
})
靑春怀旧 2024-09-15 14:54:32

如果您使用的是 .NET 3.5,则可以使用 AsEnumerable(来自 DataTableExtensions。它看起来像这样:

IEnumerable<DataRow> data = datatable.AsEnumerable();

If you're using .NET 3.5, you can use AsEnumerable (from DataTableExtensions. It would look something like this:

IEnumerable<DataRow> data = datatable.AsEnumerable();
梦里梦着梦中梦 2024-09-15 14:54:32

通过创建自定义 GridModel 可以实现这一点。
在这里,我的网格基于填充了 IDictionaries 的 IList,但这对于从 DataTable 获取的数据也应该是可能的。
诀窍是将数据结构交给自定义 GridModel 的构造函数,并让自定义 GridModel 根据数据结构生成列。
它有点难看,但效果很好。
(在带有有趣的 lambda 表达式的 VB.NET 中甚至更丑陋)

控制器操作代码:

Dim list As IList(Of IDictionary(Of String, String)) = New List(Of IDictionary(Of String, String))
Dim row1 As IDictionary(Of String, String) = New Dictionary(Of String, String)()
row1.Add("Column1", "ValueColumn1Row1")
row1.Add("Column2", "ValueColumn2Row1")
Dim row2 As IDictionary(Of String, String) = New Dictionary(Of String, String)()
row2.Add("Column1", "ValueColumn1Row2")
row2.Add("Column2", "ValueColumn2Row2")
list.Add(row1)
list.Add(row2)
ViewData("DynamicData") = list

自定义 GridModel:

Public Class DynamicGridModel
Inherits MvcContrib.UI.Grid.GridModel(Of IDictionary(Of String, String))

    Public Sub New(ByVal dataToRender As IList(Of IDictionary(Of String, String)))
        If dataToRender.Count > 0 Then
            For Each name As String In dataToRender(0).Keys
                Dim columnName As String = name
                Column.For(Function(rowData As IDictionary(Of String, String)) rowData(columnName)).Named(columnName)
            Next
        End If
    End Sub

End Class

视图中的语法:

Html.Grid(Of IDictionary(Of String, String))("DynamicData").WithModel(New DynamicGridModel(ViewData("DynamicData")))

It is possible by creating a custom GridModel.
Here I based my grid on an IList filled with IDictionaries, but this should also be possible with data taken from a DataTable.
The trick is to give the data structure to the constructor of the custom GridModel and let the custom GridModel generate columns based on the data structure.
It is a bit ugly, but it works good.
(and it is even uglier in VB.NET with the funny lambda expressions)

The controller action code:

Dim list As IList(Of IDictionary(Of String, String)) = New List(Of IDictionary(Of String, String))
Dim row1 As IDictionary(Of String, String) = New Dictionary(Of String, String)()
row1.Add("Column1", "ValueColumn1Row1")
row1.Add("Column2", "ValueColumn2Row1")
Dim row2 As IDictionary(Of String, String) = New Dictionary(Of String, String)()
row2.Add("Column1", "ValueColumn1Row2")
row2.Add("Column2", "ValueColumn2Row2")
list.Add(row1)
list.Add(row2)
ViewData("DynamicData") = list

The custom GridModel:

Public Class DynamicGridModel
Inherits MvcContrib.UI.Grid.GridModel(Of IDictionary(Of String, String))

    Public Sub New(ByVal dataToRender As IList(Of IDictionary(Of String, String)))
        If dataToRender.Count > 0 Then
            For Each name As String In dataToRender(0).Keys
                Dim columnName As String = name
                Column.For(Function(rowData As IDictionary(Of String, String)) rowData(columnName)).Named(columnName)
            Next
        End If
    End Sub

End Class

The syntax in the view:

Html.Grid(Of IDictionary(Of String, String))("DynamicData").WithModel(New DynamicGridModel(ViewData("DynamicData")))
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文