0

我正在使用 Petapoco(在 Umbraco 中)从数据库中获取 IEnumerable 并将其传递给视图。下面的代码缩写以便于概述
模型:

public class Account  
{  
    [Column("accountId")]
    [PrimaryKeyColumn(AutoIncrement = true)]
    [HiddenInput(DisplayValue = false)]
    public int accountId { get; set; }

    [Column("accountCode")]
    [Required(ErrorMessage = "Enter the account code (max 20 chars)")]
    [Display(Name = "Account code")]
    public string accountCode { get; set; }
}

控制器:

   var db = ApplicationContext.DatabaseContext.Database;
   var all = db.Query<Account>("SELECT * FROM account");
   return PartialView("_accountList", all);

部分观点:

@model IEnumerable<App.Models.AccountListViewModel>

//notice I manually set the template name because MVC does not see this as an  
//'Account' model but a 'Umbraco.Core.Persistence.Database+<Query>d__7`1[App.Models.Account]'
//model
@Html.EditorForModel("Account") 

编辑器模板:

@model App.Models.Account

<div>
   <p>account code<br/>
   @Html.TextBoxFor(x => x.accountCode, new { @class = "form-control input-sm" })
   </p>
   @Html.HiddenFor(a => a.accountId)
</div>

在上面运行时,出现以下错误:

System.InvalidOperationException:传入字典的模型项的类型为“Umbraco.Core.Persistence.Database+d__7`1[App.Models.Account]”,但此字典需要“App.Models.Account”类型的模型项'。

如何获取编辑器模板以查看此帐户模型?还是 PetaPoco 中使用编辑器模板的限制?然而奇怪的是视图接受模型作为帐户但编辑器模板不接受。

任何帮助表示赞赏!

4

1 回答 1

0

在您的部分视图中,您的模型是一个 IEnumerable,但稍后在您的编辑器模板中,您只有一个对象。

应该:

@model IEnumerable<App.Models.AccountListViewModel>

@foreach (var item in Model ) {
   Html.EditorFor(item) 
}
于 2014-11-20T11:55:51.037 回答