如何解决在保存父对象之前,如何以及在何处从UIjqgrid将子对象存储到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输入字段中,并且只有当用户提交表单时,才将它们全部发送到服务器,服务器将它们插入数据库。这是一个很好的博客文章,阐述了这一概念。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。