Asp.net mvc 在checkboxfor()中使用linq.any()时出错
模板只能用于字段访问、属性访问、一维数组索引或单参数自定义索引器表达式。 我在谷歌上搜索过,找不到更好的方法来解决这个问题,我想检查一下数据是否存在于表中,然后设置为true,否则设置为false,有什么地方可以让它工作吗?如果无法使用linq使其工作,我可以想到的是使用jQueryAjax填充表Asp.net mvc 在checkboxfor()中使用linq.any()时出错,asp.net-mvc,linq,Asp.net Mvc,Linq,模板只能用于字段访问、属性访问、一维数组索引或单参数自定义索引器表达式。 我在谷歌上搜索过,找不到更好的方法来解决这个问题,我想检查一下数据是否存在于表中,然后设置为true,否则设置为false,有什么地方可以让它工作吗?如果无法使用linq使其工作,我可以想到的是使用jQueryAjax填充表 <tbody> @foreach (var item in (ViewData["menu"] as IEnumerable<overview>))
<tbody>
@foreach (var item in (ViewData["menu"] as IEnumerable<overview>))
{
<tr>
<td>@Html.CheckBoxFor(model=>model.AccessRights.Where(m=> m.mcd ==item.mcd && m.ise=="Y").Any())
</tr>
}
</tbody>
@foreach(视图数据[“菜单”]中的变量项为IEnumerable))
{
@Html.CheckBoxFor(model=>model.AccessRights.Where(m=>m.mcd==item.mcd&&m.ise==“Y”).Any())
}
更改您的概述
视图模型,以包括例如:
public bool AccessRightsExist {get;set;}
然后在控制器中设置:
overviewModel.AccessRightsExist = dbContext.AccessRights.Where(m=> m.ise=="Y").Any();
最后,你的观点是:
<td>@Html.CheckBoxFor(model=>item.AccessRightsExist)</td>
@Html.CheckBoxFor(model=>item.AccessRightsExist)
如果没有ViewModel,请将其添加到解决方案中。是否可行?因为我需要将其与@foreach(ViewData[“menu”]中的var项作为IEnumerable)进行比较,所以请更改概览模型以包含所需的布尔值。我今天学到了一些东西:-+1,这是一个很好的答案。@postereofliperning,嗯,好的,你的话给我一些想法,让我试着玩一下我的overview类,看看它是否正确workable@retailcoder,是的,我检查了每一篇文章,以便解决这个问题