12

我有一个 ASP.NET MVC 视图,其中包含用户定义类别的复选框。

<td><% foreach (Category c in (List<Category>)ViewData["cats"]) {
       if (selCats.ContainsKey(c.ID)) { %>
       <input name="CategoryIDs" type="checkbox" value="<%=c.ID %>" checked="checked" />&nbsp;<%= c.Name%><% } 
        else { %>
       <input name="CategoryIDs" type="checkbox" value="<%=c.ID %>" />&nbsp;<%= c.Name%> <% } %>
     <% } %>
</td>

表单发布到以下控制器操作:

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Edit(int id, int [] CategoryIDs)
{
    PostsDataContext db = new PostsDataContext();
    var post = db.Posts.Single(p => p.ID == id);
    UpdateModel(post, new[] { "Title", "Subtitle", "RawContent", "PublishDate", "Slug" });
    db.SubmitChanges();
    return Redirect("/archives/" + post.Slug);
}

表单复选框将被转换为一个整数 ID 数组“CategoryIDs”,每个代表一个选定的类别。然后,我想将它们放入包含两列的关联表中:PostID 和 CategoryID。这用于在帖子和类别之间建立多对多关联。

目前我正在强制它:遍历类别,并为每个类别添加一行到包含类别 ID 的关联表,以及它所属的帖子的 ID。

但是我想知道在 ASP.NET MVC 和 LINQ to SQL 的上下文中是否有一种更简洁的方法可以自动执行此操作?

谢谢!

4

1 回答 1

7

我认为你正在做的很好......我唯一要说的是,如果你不想循环遍历 ID,你可以使用“InsertAllOnSubmit”同时添加它们(即使这真的是也只是循环):

int[] categoryIDs = new int[] { 0, 1, 2 };

dataContext.PostCategories.InsertAllOnSubmit(
categoryIDs.Select(id =>
    new PostCategory
    {
        CategoryID = id,
        PostID = myPostID
    })
);

但无论哪种方式,这仍然和你所拥有的一样。

于 2008-10-24T03:04:14.237 回答