我想知道什么更快。是将从DB查询的信息存储到ViewBag中,然后访问并显示在视图中,还是应该直接在View中进行查询。控制器是MVC中的中间层,因此在我看来,访问控制器中的DB应该更快是合乎逻辑的。
示例:
1)控制器中的--我访问DB并将信息放入ViewBag中,以便在视图中显示它。
主计长:
EVENT e = db.EVENT.Find(id);
ViewBag.event = e;
if (e.poster_id != null)
{
poster = e.DATA.path;
}
ViewBag.dict_poster = poster;意见:
<p>POSTER: @ViewBag.dict_poster;</p>2)控制器中的--我只将来自DB的一般数据放入ViewBag中,并在视图中访问它。
主计长:
EVENT e = db.EVENT.Find(id);
ViewBag.event = e;意见:
<p>
@if(ViewBag.event.poster_id != null)
{
@ViewBag.event.DATA.path;
}
</p>我很感谢你的回答和补充解释.
发布于 2011-08-09 13:56:28
您不应该直接从视图访问数据层,这应该在控制器中完成。另外,考虑将强类型视图模型传递给视图,而不是使用ViewBag。
在MVC中使用视图模型的原因请参见http://theminimalistdeveloper.com/2010/08/21/why-when-and-how-to-use-typed-views-and-viewmodel-pattern-in-asp-net-mvc/。
https://stackoverflow.com/questions/6997156
复制相似问题