2012-01-16 52 views
0

我想通过ajax更新局部视图,但它不起作用。看看这个模型类:部分视图和ajax

public class LogOnModel 
    { 
     [Required] 
     [Display(Name = "User name")] 
     public string UserName { get; set; } 

     [Required] 
     [DataType(DataType.Password)] 
     [Display(Name = "Password")] 
     public string Password { get; set; } 

     [Display(Name = "Remember me?")] 
     public bool RememberMe { get; set; } 

     public bool IsLoggedIn { get; set; } 

     public string ReturnUrl { get; set; } 
    } 

以下几种观点:

@model ITW2012Mobile.ViewModels.LogOnModel 
<div id='LogOn' style="background-color: White;"> 
    @using (Ajax.BeginForm("LogOnAjax", "Home", new AjaxOptions { UpdateTargetId = "LogOn", OnSuccess = "logInComplete" })) 
    { 
     ITW2012Mobile.ViewModels.LogOnModel m = Model; 
     @Html.EditorFor(model => model.IsLoggedIn) 
     @Html.EditorFor(model => model.ReturnUrl) 
     <div> 
      @Html.ValidationSummary() 
     </div> 
     <div> 
      @Html.LabelFor(model => model.UserName) 
      @Html.EditorFor(model => model.UserName) 
     </div> 
     <div> 
      @Html.LabelFor(model => model.Password) 
      @Html.EditorFor(model => model.Password) 
     </div> 
     <div> 
      <input type="submit" value="Login" /> 
     </div> 
    } 
</div> 

与下列的控制器类:

public ActionResult LogOnAjax(LogOnModel model) 
{ 
    if (!User.Identity.IsAuthenticated) 
    { 
     if (ModelState.IsValid) 
     { 
      if (Membership.ValidateUser(model.UserName, model.Password)) 
      { 
       FormsAuthentication.SetAuthCookie(model.UserName, model.RememberMe); 
       model.IsLoggedIn = true; 
       model.ReturnUrl = Url.Action("Index", "Home"); 
      } 
      else 
      { 
       ModelState.AddModelError("", "The user name or password provided is incorrect."); 
      } 
     } 

     // If we got this far, something failed, redisplay form 
     return PartialView("PartialViewAjaxLogOn", model); 
    } 
    else 
    { 
     return PartialView("PartialViewLogOut"); 
    } 
} 

即使用户名/密码是否正确,IsLoggedIn =真实RETURNURL !=空视图显示这些变量的空字段(但调试器显示内部的值)。为什么以及如何使它正确?

+0

注意你上面的评论'//如果我们得到了这么多,失败的东西,重新显示的形式',然而,你没有什么可以在model.returnUrl之后停止处理,所以根据你上面的代码注释是不正确的 – 2012-01-17 00:24:09

+0

没有任何理解... – John 2012-01-17 00:33:33

回答

0

尝试清除您从ModelState中你的行动被修改,或者如果您在HTML辅助使用它们的旧值将被使用的值:

ModelState.Remove("IsLoggedIn"); 
model.IsLoggedIn = true; 
ModelState.Remove("ReturnUrl"); 
model.ReturnUrl = Url.Action("Index", "Home"); 

的同时也要记住的是在成功验证和cookie的排放您不应该显示一个视图(部分在你的情况)。您应该重定向,以便客户端在随后的请求中发送身份验证Cookie。您应该重定向到返回网址。但是,由于您正在使用AJAX进行此操作,因此您应该向客户端发送一些指示,表明身份验证已成功,以便您可以在客户端上重定向。

+0

它真的帮了我,但我不明白为什么。对于两种情况,模型值都是相同的 - 对于具有清晰模型状态和没有模型状态的情况。为什么以及如何查看知道需要更新值? – John 2012-01-17 23:43:58

+0

@John,那是因为Html助手,比如TextBoxFor,HiddenFor,...首先查看模型状态时绑定它们的值,然后在模型中。这是设计。因此,如果您打算修改已发布的内容和模型状态的一部分的值,那么如果您希望后续视图中的HTML助手使用修改后的值而不是原来的值,则必须将其从模型状态中移除POST请求的一部分。 – 2012-01-17 23:46:03