我正在尝试在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>
答案 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,您可以获取单独的部分视图并将更新的视图注入页面。