Asp.Net MVC +EntityFramework主从表新增编辑操作的实现(删除操作怎么实现?)
Asp.Net MVC +EntityFramework主从表新增编辑操作的实现
对于MVC中同时对主从表的表单操作在网上现有的解决很少,而这样的操作在做业务系统中是经常为遇到的。我在网上搜索了很久都没有发现很完整的实例或非常好的解决方案,所以我很想和大家讨论一下又什么更好的解决方案。
一旦有更好的方式我会把它集成到模板中实现自动生成。所以很希望得到大家的帮助。在这里我先抛砖引玉了。
Demo代码在 https://github.com/neozhu/MVC5-Scaffolder 下载
先看一下我的Demo实例
实体类的结构
实现的操作界面如下图
功能:
查询页面上可以单击新增和编辑进行对数据维护
页面的结构是上部是维护表头,下部的Table是现实子表数据,对子表数据的维护使用bootstrap popup modal的方式操作。
具体实现
View层的代码
Index :查询Table List
Create :新增页面
Edit : 编辑页面
EditForm :Partial View内嵌在Create 和Edit页面中
_OrderDetailForm : pupup 子表维护表单页面
Create,和Edit页面通过Ajax Post 把数据提交到后台的Controller进行操作
代码如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 | <script type= "text/javascript" > var $orderdetailstable = {}; var ObjectState = "Added" ; $(document).ready(function () { $( '#orders' ).submit(function () { var actionurl = $( this ).attr( 'action' ); var orderdetails = $orderdetailstable.bootstrapTable( 'getData' ); console.log(orderdetails); var newitem = { Id:0, Customer: $( '#Customer' , '#orders' ).val(), ShippingAddress: $( '#ShippingAddress' , '#orders' ).val(), OrderDate: $( '#OrderDate' , '#orders' ).val(), ObjectState:ObjectState, OrderDetails: orderdetails }; console.log(newitem); $.ajax({ url: actionurl, type: "POST" , dataType: "json" , contentType: "application/json; charset=utf-8" , data: JSON.stringify(newitem), success: function (result) { self.location = "/Orders/Index" ; //alert("success " + result.UserName); }, error: function (result) { alert( "Failed" ); } }); return false ; }); }); </script> |
通过Jquery 获取表头和表体数据 序列化成Json对象然后Post到后台
这里有个问题关于Josn 序列化的 所有的实体 Order都集成Entity这个基类,Entity有个枚举类型的字段 [ObjectState] 用了好多方法都没有办法把这个字段提交到后台,在Controller的Create,Edit 方法中的Order就是没有[ObjectState]这个字段的值;所以在Controller层还得写很多代码来修改实体状态
Controller层代码
这里就只贴Create方法的代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 | // GET: Orders/Create public ActionResult Create() { //Detail Models RelatedProperties var orderRepository = _unitOfWork.Repository<Order>(); ViewBag.OrderId = new SelectList(orderRepository.Queryable(), "Id" , "Customer" ); var productRepository = _unitOfWork.Repository<Product>(); ViewBag.ProductId = new SelectList(productRepository.Queryable(), "Id" , "Name" ); return View(); } // POST: Orders/Create // To protect from overposting attacks, please enable the specific properties you want to bind to, for more details see http://go.microsoft.com/fwlink/?LinkId=317598. [HttpPost] //[ValidateAntiForgeryToken] public ActionResult Create([Bind(Include = "OrderDetails,Id,Customer,ShippingAddress,OrderDate" )] Order order) { if (ModelState.IsValid) { order.ObjectState = ObjectState.Added; foreach ( var detail in order.OrderDetails) { detail.ObjectState = ObjectState.Added; if (detail.Product != null ) detail.Product.ObjectState = ObjectState.Detached; } _orderService.InsertOrUpdateGraph(order); _unitOfWork.SaveChanges(); DisplaySuccessMessage( "Has append a Order record" ); //return RedirectToAction("Index"); return Json( "{Status:Success}" , JsonRequestBehavior.AllowGet); } DisplayErrorMessage(); return View(order); } |
因为没办法在前端把[ObjectState]这个字段的值序列化所以写了一个foreach来修改状态,不知道你们有没有什么好的解决方案
Popup Modal编辑子表数据代码
新增表体按钮
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | $( '#neworderdetailbutton' ). on ( 'click' , function (e) { if ($( "form" ).valid()) { var url= "/Orders/CreateOrderDetail" $. get (url , function (data) { //console.log(data); var index=-1; $( '#orderdetailformModal-body' ).html(data); $( '#rowindex' ).val(index); $( '#Id' ).val(0); $( '#orderdetailformModal' ).modal( 'toggle' ); }); } e.preventDefault(); //Return false regardless of validation to stop form submitting //prior to ajax doing its thing return false ; }) |
OrderController 添加一个新增表体和修改表体的Action用于生产对应的Partial View
我在这里也试过在OrderController中不添加对子表操作的Action,完全使用JS完成对行的操作,但在对编辑现有表体数据时出现了问题。后来注销掉了@*@Html.Partial("_OrderDetailForm")*@
现在还有非常棘手的问题就是如何进行删除操作,一旦在编辑状态下,把其中一个表体的记录删掉,删除后就没办法把数据提交到后台,而不删添加一个删除标志,这同样也会带来很多操作,如Table 在laod数据时还要把带删除标志的行筛选掉,又要添加好多代码
不知道你们是否有很好的解决方案
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
2011-02-27 Clean up your BizTalk databases