这根本不是“错误”,这不是酷人通常对MVC所做的事情。顺便说一句,我希望ASP.NET MVC的一些早期演示不要同时尝试在Linq-to- sql中进行。当然,它非常棒,非常适合MVC,但这不是必需的。 。例如:
控制器动作:
public ActionResult Index()
{
ViewData["Message"] = "Welcome to ASP.NET MVC!";
DataTable dt = new DataTable("MyTable");
dt.Columns.Add(new DataColumn("Col1", typeof(string)));
dt.Columns.Add(new DataColumn("Col2", typeof(string)));
dt.Columns.Add(new DataColumn("Col3", typeof(string)));
for (int i = 0; i < 3; i++)
{
DaTarow row = dt.NewRow();
row["Col1"] = "col 1, row " + i;
row["Col2"] = "col 2, row " + i;
row["Col3"] = "col 3, row " + i;
dt.Rows.Add(row);
}
return View(dt); //passing the DataTable as my Model
}
视图:(带有强类型为System.Data.DataTable的模型)
<table border="1">
<thead>
<tr>
<%foreach (System.Data.DataColumn col in Model.Columns) { %>
<th><%=col.Caption %></th>
<%} %>
</tr>
</thead>
<tbody>
<% foreach(System.Data.DaTarow row in Model.Rows) { %>
<tr>
<% foreach (var cell in row.ItemArray) {%>
<td><%=cell.ToString() %></td>
<%} %>
</tr>
<%} %>
</tbody>
</table>
现在,我在这里违反了ASP.NET MVC的许多原理和“最佳实践”,因此请理解,这只是一个简单的演示。创建DataTable的代码应该驻留在控制器之外的某个位置,并且View中的代码可能更好地隔离到部分(或html)助手中,以列举一些您应该 做的事情。
,则 。(关注点的分离规定了视图不应该负责 创建 它们。)在这种情况下,我将DataTable传递为实际的视图模型,但您也可以将其放入ViewData集合中。或者,您可以制作一个特定的Indexviewmodel类,其中包含DataTable和其他对象,例如欢迎消息。
我希望这有帮助!