一个控制器的两个视图

时间:2013-04-08 20:42:16

标签: c# asp.net-mvc listview

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

1 个答案:

答案 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")