【学习 jQuery EasyUI 】 jQuery EasyUI 教程 jQuery EasyUI 简介 jEasyUI 应用 jEasyUI 创建 CRUD 应用 jEasyUI 创建 CRUD 数据网格 jEasyUI 表单的 CRUD 应用 jEasyUI 创建 RSS 阅读器 jEasyUI 拖放 jEasyUI 基本的拖动和放置 jEasyUI 创建拖放的购物车 jEasyUI 创建学校课程表 jEasyUI 菜单与按钮 jEasyUI 创建简单的菜单 jEasyUI 创建链接按钮 jEasyUI 创建菜单按钮 jEasyUI 创建分割按钮 jEasyUI 布局 jEasyUI 创建边框布局 jEasyUI 创建复杂布局 jEasyUI 创建折叠面板 jEasyUI 创建标签页 jEasyUI 动态添加标签页 jEasyUI 添加自动播放标签页 jEasyUI 创建 XP 风格左侧面板 jEasyUI 数据网格 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 创建异步提交表单 jEasyUI 表单验证 jEasyUI 创建树形下拉框 jEasyUI 格式化下拉框 jEasyUI 过滤下拉数据网格 jEasyUI 参考手册 jQuery EasyUI 插件 jQuery EasyUI 扩展

jEasyUI 扩展行显示细节学习笔记

1. 什么是 jEasyUI

jEasyUI 是一款基于 jQuery 的 UI 库,它为开发者提供了丰富的 UI 组件和各种功能,非常方便易用。其中扩展行组件是一个强大的功能组件,能够在数据表格中显示扩展行,用于显示详细信息或者编辑某一行的数据。

2. 扩展行的基本使用

2.1 引入扩展行组件

首先需要在 HTML 中引入 jEasyUI 和扩展行组件的脚本文件。例如:

htmlCopy Code
<link rel="stylesheet" type="text/css" href="jeasyui/themes/default/easyui.css"> <link rel="stylesheet" type="text/css" href="jeasyui/themes/icon.css"> <script type="text/javascript" src="jeasyui/jquery.min.js"></script> <script type="text/javascript" src="jeasyui/jquery.easyui.min.js"></script> <script type="text/javascript" src="jeasyui/plugins/datagrid-detailview.js"></script>

2.2 初始化扩展行组件

初始化数据表格后,需要调用 detailview 方法来启用扩展行功能。例如:

javascriptCopy Code
$('#dg').datagrid({ url: 'get_data.php', columns:[[ {field:'itemid',title:'Item ID',width:80}, {field:'productid',title:'Product ID',width:100}, {field:'listprice',title:'List Price',width:80,align:'right'} ]], view: detailview, detailFormatter:function(index,row){ return '<div class="ddv"></div>'; }, onExpandRow: function(index,row){ var ddv = $(this).datagrid('getRowDetail',index).find('div.ddv'); ddv.panel({ border:false, cache:true, href:'get_details.php?itemid='+row.itemid, onLoad:function(){ $('#dg').datagrid('fixDetailRowHeight',index); } }); $('#dg').datagrid('fixDetailRowHeight',index); } });

其中 view 属性指定了使用扩展行组件,detailFormatter 方法返回扩展行的 HTML 内容,onExpandRow 事件处理方法则加载并显示扩展行的内容。

3. 实例演示

下面提供一个简单的实例,演示如何在数据表格中显示扩展行。数据表格包含三列:编号、名称和价格,点击一行后可以展开扩展行显示更多详细信息。

htmlCopy Code
<body> <table id="dg" style="width:700px;height:250px"></table> <script> $(function(){ $('#dg').datagrid({ url:'get_data.php', columns:[[ {field:'id',title:'ID',width:100}, {field:'name',title:'Name',width:200}, {field:'price',title:'Price',width:100} ]], 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:'get_details.php?id='+row.id, fitColumns:true, singleSelect:true, columns:[[ {field:'attr',title:'Attribute',width:100}, {field:'val',title:'Value',width:200} ]], onResize:function(){ $('#dg').datagrid('fixDetailRowHeight',index); }, onLoadSuccess:function(){ setTimeout(function(){ $('#dg').datagrid('fixDetailRowHeight',index); },0); } }); $('#dg').datagrid('fixDetailRowHeight',index); } }); }); </script> </body>

get_data.php 文件中返回如下数据:

jsonCopy Code
[{ "id": 1, "name": "Product A", "price": 100 },{ "id": 2, "name": "Product B", "price": 200 },{ "id": 3, "name": "Product C", "price": 300 }]

get_details.php 文件中根据传递的 ID 参数返回该产品的详细信息,例如:

jsonCopy Code
[{ "attr": "Color", "val": "Red" },{ "attr": "Size", "val": "Large" },{ "attr": "Weight", "val": "1.5 kg" }]

4. 总结

扩展行是 jEasyUI 中非常实用的一个功能组件,能够为数据表格增加更多的细节显示。开发者可以根据具体的需求来定制扩展行的样式和内容,提高用户体验。