jQuery EasyUI
jQuery EasyUI 简介
jEasyUI 创建 CRUD 应用
jEasyUI 创建 CRUD 数据网格
jEasyUI 表单的 CRUD 应用
jEasyUI 创建 RSS 阅读器
jEasyUI 基本的拖动和放置
jEasyUI 创建拖放的购物车
jEasyUI 创建学校课程表
jEasyUI 创建简单的菜单
jEasyUI 创建链接按钮
jEasyUI 创建菜单按钮
jEasyUI 创建分割按钮
jEasyUI 创建边框布局
jEasyUI 创建复杂布局
jEasyUI 创建折叠面板
jEasyUI 创建标签页
jEasyUI 动态添加标签页
jEasyUI 添加自动播放标签页
jEasyUI 创建 XP 风格左侧面板
jEasyUI 转换 HTML 表格为数据网格
jEasyUI 取得选中行数据
jEasyUI 添加查询功能
jEasyUI 添加工具栏
jEasyUI 创建复杂工具栏
jEasyUI 设置冻结列
jEasyUI 动态改变列
jEasyUI 格式化列
jEasyUI 设置排序
jEasyUI 自定义排序
jEasyUI 创建列组合
jEasyUI 添加复选框
jEasyUI 自定义分页
jEasyUI 启用行内编辑
jEasyUI 扩展编辑器
jEasyUI 列运算
jEasyUI 合并单元格
jEasyUI 创建自定义视图
jEasyUI 创建页脚摘要
jEasyUI 条件设置行背景颜色
jEasyUI 创建属性网格
jEasyUI 扩展行显示细节
jEasyUI 显示海量数据
jEasyUI 添加分页组件
jEasyUI 创建简单窗口
jEasyUI 自定义窗口工具栏
jEasyUI 窗口与布局
jEasyUI 创建对话框
jEasyUI 自定义对话框
jEasyUI 使用标记创建树形菜单
jEasyUI 创建异步树形菜单
jEasyUI 树形菜单添加节点
jEasyUI 创建带复选框的树形菜单
jEasyUI 树形菜单拖放控制
jEasyUI 树形菜单加载父/子节点
jEasyUI 创建基础树形网格
jEasyUI 创建复杂树形网格
jEasyUI 树形网格动态加载
jEasyUI 树形网格添加分页
jEasyUI 树形网格惰性加载节点
jEasyUI 创建异步提交表单
jEasyUI 表单验证
jEasyUI 创建树形下拉框
jEasyUI 格式化下拉框
jEasyUI 过滤下拉数据网格
jQuery EasyUI 插件
jQuery EasyUI 扩展
 

jEasyUI 创建子网格

阅读:86      收藏:0      [点我收藏+]

jQuery EasyUI 数据网格 -创建子网格

使用数据网格(datagrid)的详细视图,用户可以展开一行来显示附加的详细信息。 任何内容都可以加载作为行详细,子网格也可以动态加载。 本教程将向您展示如何在主网格上创建一个子网格。

步骤 1:创建主网格

<table id="dg" style="width:700px;height:250px"
		url="datagrid22_getdata.php" 
		title="DataGrid - SubGrid"
		singleSelect="true" fitColumns="true">
	<thead>
		<tr>
			<th field="itemid" width="80">Item ID</th>
			<th field="productid" width="100">Product ID</th>
			<th field="listprice" align="right" width="80">List Price</th>
			<th field="unitcost" align="right" width="80">Unit Cost</th>
			<th field="attr1" width="220">Attribute</th>
			<th field="status" width="60" align="center">Status</th>
		</tr>
	</thead>
</table>

步骤 2:设置详细视图来显示子网格

为了使用详细视图,请记得在页面头部引用视图脚本文件。

<script type="text/javascript" src="http://www.bubuko.com/try/jeasyui/datagrid-detailview.js"></script>
$(‘#dg‘).datagrid({
	view: detailview,
	detailFormatter:function(index,row){
		return ‘<div style="padding:2px"><table class="ddv"></table></div>‘;
	},
	onExpandRow: function(index,row){
		var ddv = $(this).datagrid(‘getRowDetail‘,index).find(‘table.ddv‘);
		ddv.datagrid({
			url:‘datagrid22_getdetail.php?itemid=‘+row.itemid,
			fitColumns:true,
			singleSelect:true,
			rownumbers:true,
			loadMsg:‘‘,
			height:‘auto‘,
			columns:[[
				{field:‘orderid‘,title:‘Order ID‘,width:100},
				{field:‘quantity‘,title:‘Quantity‘,width:100},
				{field:‘unitprice‘,title:‘Unit Price‘,width:100}
			]],
			onResize:function(){
				$(‘#dg‘).datagrid(‘fixDetailRowHeight‘,index);
			},
			onLoadSuccess:function(){
				setTimeout(function(){
					$(‘#dg‘).datagrid(‘fixDetailRowHeight‘,index);
				},0);
			}
		});
		$(‘#dg‘).datagrid(‘fixDetailRowHeight‘,index);
	}
});

当用户点击展开按钮(‘+‘)时,‘onExpandRow‘ 事件将被触发。 我们创建一个新的带有三列的子网格。 当子网格数据加载成功时或者改变尺寸大小时,请记得对主网格调用 ‘fixDetailRowHeight‘ 方法。

步骤 3:服务器端代码

datagrid22_getdata.php
$result = array();

include ‘conn.php‘;

$rs = mysql_query("select * from item where itemid in (select itemid from lineitem)");

$items = array();
while($row = mysql_fetch_object($rs)){
	array_push($items, $row);
}

echo json_encode($items);
datagrid22_getdetail.php
include ‘conn.php‘;

$itemid = mysql_real_escape_string($_REQUEST[‘itemid‘]);

$rs = mysql_query("select * from lineitem where itemid=‘$itemid‘");
$items = array();
while($row = mysql_fetch_object($rs)){
	array_push($items, $row);
}
echo json_encode($items);


关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!