C#MVC,未在视图渲染上调用控制器操作

时间:2013-09-14 00:05:05

标签: c# asp.net-mvc

我正在尝试在C#MVC 4.5中创建单个页面应用程序。

在我的应用程序中,我将有一个主视图,它在其中调用3个单独的视图。 所有这三个视图彼此独立地工作并且自己刷新。

出于某种原因,在渲染视图时,不会调用这3个视图的控制器方法。 有什么想法吗?

控制器:

public ActionResult Index()
{
    if (!_instance.Users.CheckUserSkillsExist(WebSecurity.CurrentUserName))
    {
        return RedirectToAction("CreateChar");
    }

    _instance.GameBase.GetBaseData();

    return View();
}

public ActionResult PlayerDisplayStats()
{
    var user = _instance.Users.GetUserSkills( WebSecurity.CurrentUserName);
    var userModel = new UserModel(user);
    return View(userModel);
}

查看:Index.cshtml

<div class="span2 offset1">
        <div class="span12">
            @RenderPage("~/Views/Game/PlayerDisplayStats.cshtml");
        </div>
        <div class="span2">
            @RenderPage("~/Views/Game/GameNavigator.cshtml");        
        </div>
    </div>
    <div class="span8">
        @RenderPage("~/Views/Game/MainWindow.cshtml");        
   </div>

查看:PlayerDisplayStats.cshtml

<div class="row-fluid tileOpaque">
    <div class="span12 content">
        <div class="img avatar">               
        </div>
        <div class="span12">
            <div class="span6 stat">
                @Html.LabelFor(m => m.StrVal)
                @Html.DisplayFor(m => m.StrVal)
            </div>
            <div class="span6 stat">
                Det:
            </div>
        </div>
    </div>
</div>

1 个答案:

答案 0 :(得分:2)

我认为您的问题可能是由于使用@RenderPage而不是@ Html.Action。使用@ Html.Action意味着您的视图将通过控制器进行,因此在执行此操作时会获得必要的模型。 @RenderPage只是在响应中包含视图。我鼓励您阅读此SO条目以了解差异:

Html.Partial vs Html.RenderPartial & Html.Action vs Html.RenderAction

你(可能)最终得到的是这样的......

<div class="span2 offset1">
    <div class="span12">
        @Html.Action("PlayerDisplayStats")
    </div>
    <div class="span2">
        @Html.Action("GameNavigator")
    </div>
</div>
<div class="span8">
    @Html.Action("MainWindow")
</div>

您需要更改控制器以返回PartialView ...

public ActionResult PlayerDisplayStats()
{
    var user = _instance.Users.GetUserSkills( WebSecurity.CurrentUserName);
    var userModel = new UserModel(user);
    return PartialView(userModel);
}

稍后,使用jQuery,您可以获取单独的部分视图并将更新的视图注入页面。