我正在使用 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 中使用编辑器模板的限制?然而奇怪的是视图接受模型作为帐户但编辑器模板不接受。
任何帮助表示赞赏!