一个控制器有两个视图
本文关键字:两个 视图 一个 控制器 | 更新日期: 2023-09-27 18:08:02
我目前有一个视图页面,列出用户作为一个画廊与他们的形象,但我也想创建一个视图页面,列出用户的名称。我想使用一个控制器为他们两个,我创建了一个ListView
页面,并在原始的View
页面中通过图像显示用户-我有一个链接来查看ListView
页面。我试着点击链接,但页面没有显示出来。以下是我的内容:
图片查看页面
<h2>Users</h2>
<div>
<a href="~/Views/Users/ListView">Click Here for List view</a>
</div>
<section id="Images">
<section id="users" data-bind="foreach: Users">
<div id="nameImage">
<figure id="content">
<img width="158" height="158" alt="Gravatar" data-bind="attr:{src: GravatarUrl}"/>
<figcaption>
...
</figcaption>
</figure>
<p data-bind="text:Name"></p>
</div>
</section>
</section>
@section scripts{
@Scripts.Render("~/bundles/user" + ViewBag.Layout.AppVersionForUrls)
<script type="text/javascript">
(function ($) {
$.views.User.GetUser('@url');
})(jQuery);
</script>
}
列表视图页
<div class="accordion-inner">
<div data-bind="foreach: Users">
<div>
<img width="158" height="158" alt="Gravatar" data-bind="attr:{src: GravatarUrl}"/>
<p data-bind="text:Name"></p>
</div>
</div>
@section scripts{
@Scripts.Render("~/bundles/user" + ViewBag.Layout.AppVersionForUrls)
<script type="text/javascript">
(function ($) {
$.views.User.GetUser('@url');
})(jQuery);
</script>
}
控制器public ActionResult View(int id)
{
// get the menu from the cache, by Id
ViewBag.SideBarMenu = SideMenuManager.GetRootMenu(id);
ViewBag.UserApiURL = "/api/User/" + id.ToString();
return View();
}
public ActionResult ListView(int id)
{
// get the menu from the cache, by Id
ViewBag.SideBarMenu = SideMenuManager.GetRootMenu(id);
ViewBag.RosterApiURL = "/api/User/ListView" + id.ToString();
return View();
}
MVC中的概念是,您永远不会链接到视图,而是链接到控制器中的操作,然后决定(基于传递的参数)应该呈现哪个视图和使用什么模型。如果你的控制器名为UsersController
<a href="~/Views/Users/ListView">Click Here for List view</a>
行应该是:
<a href="/Users/ListView">Click Here for List view</a>
或者更好的
@Html.ActionLink("ListView")