0

我有我的主页动态创建选项卡(jQuery UI 选项卡)并使用 Ajax 在其上加载部分视图。此局部视图具有viewmodel, 并包含其他局部视图。部分视图是strTypd针对viewmodel. 当我尝试传递元素时,出现错误。

“主要部分观点”

@model HMSDB.ViewModels.vm_administrar_permisos

<div id="PerAdmGroupBoxUser">

  <h3>Seleccion de usuarios</h3>
  <div>
      <div id="PerAdmUsrGrid">          
          @Html.Partial("_BuscarUsuario", @Model.vmBuscarUsuario) //<-- ERROR

      </div>
      <div id="PerAdmUsrData">
          @Html.Action("_DetalleUsuario", "Usuario")
      </div>
  </div>
</div>

主要局部视图的模型:

  public class vm_administrar_permisos
    {
        public vm_usuario_seleccionado vmUsuarioSeleccionado { get; set; }
        public vm_buscar_usuario vmBuscarUsuario { get; set; }
        public IEnumerable<Permisos_Rol_User> roles { get; set; }
        public IEnumerable<Permisos_Grupo_User> grupos { get; set; }
    }

子部分视图:

@model HMSDB.ViewModels.vm_buscar_usuario


  <h3>Seleccion de usuarios</h3>

无效操作异常:

The passed model´s element to the dictionary is 
of type:'HMSDB.ViewModels.vm_administrar_permisos', but this dictionary requires a
model´s element of type 'HMSDB.ViewModels.vm_buscar_usuario'

编辑:父部分视图调用:

   function getTabContent(idT, urlC) {                               //ajax call to partial view
      $.ajax({
         url: urlC,
        type: 'GET',
       async: false,
          success: function (result) {
              $("#"+idT).html(result);
    }
  });

};

控制器:

public ActionResult _Administrar()
{
    vm_administrar_permisos model = new vm_administrar_permisos();

    model.grupos = db_cm.Permisos_Grupo_User.Include("Permisos_Grupo")
                   .Where(gu => gu.id_user == HttpContext.User.Identity.Name && gu.conceder == true);

    model.roles = db_cm.Permisos_Rol_User.Include("Permisos_Rol")
                  .Where(ur => ur.id_user == HttpContext.User.Identity.Name && ur.conceder == true);  
    return PartialView(model);
}
4

1 回答 1

1

我怀疑你在某处有过时的标记版本(例如_Administrar.cshtml)。Controller.PartialView尝试指定以 "~" 作为and的第一个参数开头的视图的完整路径Html.Partial

另外,您是否遗漏了model.vmBuscarUsuario创建/分配的代码?

于 2013-06-06T19:20:39.053 回答