Asp.net mvc ASP MVC-多对多关系
老实说,我已经花了一个多小时寻找这个问题的满意答案。所以不是我没有找到答案,只是我觉得不是完全正确的答案。这可能只是意味着我在寻找一颗不存在的银弹 在包含多对多关系的EF(代码优先)模型的asp mvc中,如何将该关系绑定到复选框,然后将这些更改优雅地传播到数据库中 如果视图仅返回已选中复选框的值,则我不再知道以前选中了哪些值。我是否再次拉回原始对象,然后比较两者?它感觉很脏,可能是因为我太习惯于让EF魔法管理对象上已更改的属性 我已经有一个肮脏的版本,我不满意Asp.net mvc ASP MVC-多对多关系,asp.net-mvc,entity-framework,Asp.net Mvc,Entity Framework,老实说,我已经花了一个多小时寻找这个问题的满意答案。所以不是我没有找到答案,只是我觉得不是完全正确的答案。这可能只是意味着我在寻找一颗不存在的银弹 在包含多对多关系的EF(代码优先)模型的asp mvc中,如何将该关系绑定到复选框,然后将这些更改优雅地传播到数据库中 如果视图仅返回已选中复选框的值,则我不再知道以前选中了哪些值。我是否再次拉回原始对象,然后比较两者?它感觉很脏,可能是因为我太习惯于让EF魔法管理对象上已更改的属性 我已经有一个肮脏的版本,我不满意 [HttpPost]
[HttpPost]
public ActionResult Edit(int id, FormCollection collection)
{
try
{
// TODO: Add insert logic here
Program p = _programRep.GetByID(id);
//manually update properties
//change to model binding later
EditPolicies(ref p, collection["SelectedPolicies"].ToString().Split(','));
_programRep.Save(p);
return RedirectToAction("Index");
}
catch
{
return View();
}
}
private void EditPolicies(ref Program c, string[] selectedvals)
{
//I could do comparison logic here
int count = c.Policies.Count;
for (int i = 0; i < count; i++)
{
c.Policies.Remove(c.Policies.ElementAt(0));
}
for (int i = 0; i < selectedvals.Count(); i++)
{
Policy g = _policyRep.GetByID(int.Parse(selectedvals[i]));
c.Policies.Add(g);
}
}
[HttpPost]
公共操作结果编辑(int id,FormCollection集合)
{
尝试
{
//TODO:在此处添加插入逻辑
Program p=_programRep.GetByID(id);
//手动更新属性
//稍后更改为模型绑定
EditPolicys(参考p,集合[“SelectedPolicys”].ToString().Split(',');
_程序代表保存(p);
返回操作(“索引”);
}
抓住
{
返回视图();
}
}
私有无效编辑策略(参考程序c,字符串[]selectedvals)
{
//我可以在这里做比较逻辑
int count=c.Policies.count;
for(int i=0;i
我不太确定您希望如何实现这一点,因此我不知道您在寻找什么,但这是正确的方法,而且是经过设计的
有很多建模案例。但愿我保存了我找到的链接,并提供了一个完美的示例,在该示例中,从集合中删除对象只是意味着缺少一个关系,而不是需要删除一行
我想补充的唯一优雅之处是:
c.Policies.AddRange(_policyRep.GetByIDs(selectedvals[i]));
真的没有一种优雅的方式来做你想做的事。我通常会做一些类似于你正在做的事情(删除现有的,然后添加新的)。。。你是对的。谢谢我保留了大致相同的控制器代码,但为自己构建了一些复选框帮助器方法,以减少视图中的痛苦。它通常从模型中获取项目的主集合和选定项目的列表,并呈现结果。然后我在控制器中运行这个代码段。