在保存父对象之前,如何(以及在​​何处)从UI(jqgrid)将子对象存储到asp.net-mvc服务器

我有一个asp.net-mvc网站,我使用nhibernate。我遇到一个问题,我的UI需要将子项添加到父对象,但是该父对象尚未插入(因此没有ID) 详细信息如下: 我有一个基本的“详细信息”页面,该页面是一种形式(一堆输入控件),用于表示对象(在这种情况下为Project对象)的属性,其中具有用于Name的文本框,用于描述的textarea等。 。 一个(简化视图)Project对象如下所示
public class Project
{
      public string Name;
      public string Description;
      public List<Project> Dependencies;
      public int Id;
}
我重用此屏幕以添加新项目(启动时所有控件均为空白) 我重用此屏幕来编辑现有项目(在给定项目ID的情况下,我从服务器中加载所有控件) 现在,问题在于围绕UI向项目(列表)的Dependency属性添加和删除Dependencies项目。它有点复杂,但是我不能只使用常规的多选列表框,因为需要搜索依赖项(因为有成千上万个依赖项) 我决定用来显示依赖关系列表的UI是jqGrid。 当您单击jqgrid的“添加”按钮时,它会弹出一个小对话框以添加依赖项 当您选择一个项目时,它随后调用服务器向该项目添加一个依赖项,关闭弹出窗口,然后刷新\“ Dependency grid \”,向您显示依赖项项目的最新列表。 这是我添加的依赖代码:
public ActionResult AddDepedency(Dependency dependency)
{
      var project = GetProjectFromRepository(dependency.ProjectId);
      var projectDependency = GetProjectFromRepository(dependency.DependencyProjectId);

      project.Dependencies.Add(projectDependency);
      this.Repository.Save(project);
      this.Repository.Commit();
}
顺便提一下,这是我的ProjectMap类中流畅的nhibernate布线的关系:
  HasMany(x => x.Dependencies).AsBag().Inverse().Cascase.AllDeleteOrphan().Fetch.Select().BatchSize(80);
当我在编辑屏幕上执行此操作时,因为我已经有一个项目ID,所以它工作正常。 但是我无法弄清楚如何使其在ADD项目屏幕上工作,因为人们会在保存初始项目本身之前尝试向项目添加依赖项,因此尚无ID。 我应该使用一些会话缓存来临时存储此列表吗?所以当我实际去提交要插入的项目时,那时候我在项目插入成功之后将当时的所有依赖项附加到主项目上? 一种选择是,我完全不支持在ADD项目页面上添加依赖项,而仅在EDIT项目页面上支持它,但这似乎会让用户感到烦恼。 有没有人遇到过这个问题并且可以提供任何建议?     
已邀请:
我个人将新的依赖项存储到HTML输入字段中,并且只有当用户提交表单时,才将它们全部发送到服务器,服务器将它们插入数据库。这是一个很好的博客文章,阐述了这一概念。     

要回复问题请先登录注册