5

我试图让一些 MVC4 视图显示在 jQuery 选项卡中。这是我的代码:

<div id="tabs">
    <ul>
        <li><a href="#appone">App One</a></li>
        <li><a href="#apptwo">App Two</a></li>
    </ul>
    <div id="appone">
        @{ Html.RenderPartial("~/Views/AppOne/Index.cshtml"); }
    </div>
    <div id="apptwo">
        @{ Html.RenderPartial("~/Views/AppTwo/Index.cshtml"); }
    </div>
</div>

问题是第一个选项卡内容显示得很好 - 但第二个是空的。似乎未呈现部分视图。

有没有办法在页面加载时强制 jQuery 选项卡更新所有选项卡的内容,或者强制我的部分视图在页面加载时呈现?

4

1 回答 1

4

这是我正在积极处理的代码,效果很好:

登录.cshtml

@{
    AjaxOptions optsLogin = new AjaxOptions { UpdateTargetId = "login-tab-login" };
    AjaxOptions optsRegister = new AjaxOptions { UpdateTargetId = "login-tab-register" };
}
<section id="login-tabs">
    <ul>
        <li><a href="#login-tab-login">Returning Customers</a></li>
        <li><a href="#login-tab-register">New Customers</a></li>
    </ul>
    @using (Ajax.BeginForm("Login", "Account", optsLogin, new { id = "form-login" }))
    {
        <div id="login-tab-login">
            @Html.Partial("Account/_Login")
        </div>
    }
    @using (Ajax.BeginForm("Register", "Account", optsRegister, new { id = "form-register" }))
    {
        <div id="login-tab-register">
            @Html.Partial("Account/_Register")
        </div>
    }
</section>
<script type="text/javascript">
    $(function() {
        $('#login-tabs').tabs();
    });
</script>

我的部分视图位于 Account 子文件夹的 Shared 文件夹中。此外,每个局部视图都有自己的模型。除此之外,实现没什么特别的......

更新

我添加了代码以在两个选项卡上实现 Ajax 调用。选项卡部分上方的代码块包含AjaxOptions两个<form>元素的对象。您的控制器需要看起来像这样:

AccountController.cs

public class AccountController : Controller
{
   ...
   [HttpGet]
   public ActionResult Login()
   {
       ...
       return View();
   }

   [HttpPost]
   public ActionResult Login(LoginModel model)
   {
       ...
       if (ModelState.IsValid)
           return RedirectToAction("Index", "Home")
       else
           return PartialView("/Account/_Login", model);
   }

   [HttpPost]
   public ActionResult Register(RegisterModel model)
   {
       ...
       if (ModelState.IsValid)
           return RedirectToAction("Index", "Home")
       else
           return PartialView("/Account/_Register", model);
   }
}

Login GETaction 方法呈现整个页面,包括和_Layout.cshtml视图_ViewStart.cshtml。我的部分视图_Login.cshtml_Register.cshtml保存条目表单的 HTML 元素。每个局部视图都有自己的提交按钮:

<input type="submit" value="<Whatever you want to display>" />

因为每个部分视图调用都封装在自己的using (Ajax.BeginForm(...))块中,并且我给了每个<form>自己的id属性,所以我可以添加 JavaScript 代码来劫持submit事件。根据submit按下的哪个,它将执行与Ajax.BeginForm(...)调用中指定的动作和控制器相关联的动作方法。就我而言,如果表单数据通过验证,控制器将自动重定向到/Home/Index.

但是,如果验证失败,则操作方法将简单地将我的部分视图的渲染版本发送回浏览器,并将其放置UpdateTargetIdAjaxOptions<form>. 由于默认InsertionMode值为Replace,视图引擎将简单地用新版本替换旧版本的部分视图,并包含表单数据和验证消息(如果包含)。

我没有包括的唯一与代码相关的项目是我的部分视图,就 jQuery 选项卡功能而言,这真的无关紧要。我的部分视图中没有任何额外的 JavaScript,并且AccountController我没有包含的额外代码特定于调用我的外部 Web API 控制台应用程序和设置授权 cookie。我将 Google 的 CDN 用于我的 jQuery 和 jQuery UI 声明,而不是在本地托管 JavaScript。

你需要一段时间来思考你必须做的事情。但是,一旦你掌握了它,你就掌握了它并且知识是可以转移的。这不是WebForms,谢天谢地。

于 2013-04-17T01:12:45.880 回答