私の問題は、ViewModel プロパティがアクション パラメーターにバインドされていないことです。コードを教えていただければ、より明確になると思います。
次のようなモデルがあります。
namespace Sima3.Models
{
using System;
using System.Collections.Generic;
public partial class Usuario
{
public string Login { get; set; }
public string NombreCompleto { get; set; }
public short Organigrama { get; set; }
public int Interno { get; set; }
public string EMail { get; set; }
}
}
そして、別のファイルのこの部分クラスに DataAnnotations を追加しました (このモデルは EntityFramework によって自動的に生成されたため)、Login プロパティのリモート検証に注意してください。
namespace Sima3.Models
{
[MetadataType(typeof(UsuarioMetaData))]
public partial class Usuario
{
}
public class UsuarioMetaData
{
[Display(Name = "Nombre de Usuario")]
[Remote("NoExisteUsuario", "Validation")]
[Required]
public string Login { get; set; }
[Display(Name = "Nombre y Apellido")]
[Required]
public string NombreCompleto { get; set; }
[Display(Name = "Sector")]
[Required]
public short Organigrama { get; set; }
[Required]
public int Interno { get; set; }
[EmailAddress]
[Required]
public string EMail { get; set; }
}
}
今、タイプ Usuario のプロパティと、View をレンダリングするために必要なその他のものを含む ViewModel があります。
namespace Sima3.ViewModels.PedidoViewModels
{
public class AgregarViewModel
{
public Usuario Usuario { get; set; }
public Pedido Pedido { get; set; }
public SelectList ListaSectores { get; set; }
public SelectList ListaEstados { get; set; }
public SelectList ListaPrioridades { get; set; }
public SelectList ListaTipos { get; set; }
public SelectList ListaDirecciones { get; set; }
}
}
そして、私のビューは次のようになります(もっと見る必要がある場合は、その一部のみを投稿します):
@using (Ajax.BeginForm("Crear", "Usuario", null,
new AjaxOptions
{
OnSuccess = "UsuarioCreadoSuccess",
HttpMethod = "Post"
}
, new { @class = "form-horizontal", id = "FormUsuario" }))
{
@Html.AntiForgeryToken()
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h4 class="modal-title title">Nuevo Usuario</h4>
</div>
<div class="modal-body">
@Html.ValidationSummary(true)
<div class="form-group">
@Html.LabelFor(model => model.Usuario.Login, new { @class = "col-lg-4 control-label" })
<div class="col-lg-7">
@Html.TextBoxFor(model => model.Usuario.Login, new { @class = "form-control"})
@Html.ValidationMessageFor(model => model.Usuario.Login)
</div>
</div>
さて、重要な部分は TextBoxFor です。次の HTML をレンダリングします。
<input class="form-control valid" data-val="true" data-val-remote="'Nombre de Usuario' is invalid." data-val-remote-additionalfields="*.Login" data-val-remote-url="/Validation/NoExisteUsuario" data-val-required="El campo Nombre de Usuario es obligatorio." id="Usuario_Login" name="Usuario.Login" type="text" value="">
ご覧のとおり、テキスト ボックスの名前はname="Usuario.Login" です。
そして、リモート検証によって呼び出されるコントローラー アクションは次のようになります。
public JsonResult NoExisteUsuario([Bind(Prefix="Usuario")]string Login)
{
Usuario usuario = db.Usuarios.Find(Login);
if (usuario != null)
{
var MensajeDeError = string.Format("El usuario {0} ya existe", Login);
return Json(MensajeDeError, JsonRequestBehavior.AllowGet);
}
else
{
return Json(true, JsonRequestBehavior.AllowGet);
}
}
この Action にブレークポイントを設定してヒットするのですが、Login が null になります。Google Chrome のデバッガーで http リクエスト ヘッダーを確認したところ、フォームが次のように送信されていることがわかります: Usuario.Login: asdasdasd.
質問は簡単です。どうすればバインドできますか?
ちなみにMVC5を使っています。
ありがとう。