我目前有一个视图页面,将用户列为带有图像的图库,但我还想创建一个按名称列出用户的视图页面。我想为它们使用一个控制器,我创建了一个ListView
页面,并在orginial 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();
}
答案 0 :(得分:5)
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")