当切换datagrid视图到”detailview”时,用户可以展开一行来显示该行下面的任何详细信息。此功能允许用户为放置在行详细信息面板中的编辑表单提供恰当的布局。在本教程中,我们使用DataGrid组件来减少编辑表单所占用的空间。
Step 1:在HTML标记中创建DataGrid
First Name | Last Name | Phone |
---|
Step 2:为DataGrid应用详细视图
$('#dg').datagrid({ view: detailview, detailFormatter:function(index,row){ return ''; }, onExpandRow: function(index,row){ var ddv = $(this).datagrid('getRowDetail',index).find('div.ddv'); ddv.panel({ border:false, cache:true, href:'show_form.php?index='+index, onLoad:function{ $('#dg').datagrid('fixDetailRowHeight',index); $('#dg').datagrid('selectRow',index); $('#dg').datagrid('getRowDetail',index).find('form').form('load',row); } }); $('#dg').datagrid('fixDetailRowHeight',index); } });
若要使用DataGrid的详细视图,那么就在html 页面头部引入”datagrid-detailview.js”文件。
我们使用”detailFormatter”函数来生成行详细信息内容。在这种情况下,我们返回一个用于放置编辑表单的空的 。当用户点击该行展开按钮(”+”)时,”onExpandRow”事件将被触发,我们可以通过AJAX加载编辑表单。使用getRowDetail方法可以获得该行的详细信息容器,因此我们能够查找到该行的详细信息面板。在行详细信息中创建面板,并从”show_form.php”中加载返回的编辑表单。
Step 3:创建编辑表单
从服务器中加载编辑表单。
show_form.php
Step 4:保存或取消编辑
调用”saveItem”函数来保存用户,或调用”cancelItem”函数来取消编辑。
function saveItem(index){ var row = $('#dg').datagrid('getRows')[index]; var url = row.isNewRecord ? 'save_user.php' : 'update_user.php?id='+row.id; $('#dg').datagrid('getRowDetail',index).find('form').form('submit',{ url: url, onSubmit: function{ return $(this).form('validate'); }, success: function(data){ data = eval('('+data+')'); data.isNewRecord = false; $('#dg').datagrid('collapseRow',index); $('#dg').datagrid('updateRow',{ index: index, row: data }); } }); }
确定首先要发布哪一个URL,然后查找表单对象,并调用”submit”方法来提交表单数据。当数据保存成功后,收起并更新行数据。
function cancelItem(index){ var row = $('#dg').datagrid('getRows')[index]; if (row.isNewRecord){ $('#dg').datagrid('deleteRow',index); } else { $('#dg').datagrid('collapseRow',index); } }
当取消编辑操作时,如果该行是新行而且还没有保存,那么直接删除该行,否则收起该行。
下载EasyUI示例:easyui-crud-demo.zip
本站文章除注明转载外,均为本站原创或翻译
海报
0 条评论
117
相关文章
本站已关闭游客评论,请登录或者注册后再评论吧~