我老老实实地找了一个多小时才能得到满意的答案。所以并不是我没有找到答案,而是我认为不完全正确的答案。这可能仅仅意味着我正在寻找一个不存在的银弹。
在包含多对多关系的EF(代码优先)模型的asp mvc中,如何将该关系绑定到复选框,然后将这些更改优雅地传播到我的数据库。
如果视图仅返回已选中复选框的值,则我不再知道先前检查过哪些值。我是否再次拉回原始物体然后比较两者?它感觉很脏,可能是因为我已经习惯让EF魔法管理对象上已经改变的属性。
我已经有了一个我不满意的脏版本。
[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);
}
}
答案 0 :(得分:1)
我不太确定你对此的期望如何,所以我不知道你在寻找什么,但这是正确的方法和设计。
有很多建模案例。希望我保存了我发现的完美示例中的链接,其中从集合中删除对象只是意味着缺少关系而不是需要删除行。
我要添加的唯一优雅是:
c.Policies.AddRange(_policyRep.GetByIDs(selectedvals[i]));