【学习 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 启用行内编辑学习笔记

什么是 jEasyUI?

jEasyUI 是一个基于 jQuery 的 UI 插件库,提供了大量的易于使用且具有高度可定制化的 UI 组件,包括表格、对话框、提示框、树形菜单等。使用 jEasyUI 可以快速构建出具有美观交互效果的 Web 应用程序,并减少开发时间和成本。

什么是行内编辑?

行内编辑指的是用户在表格、列表或其他控件中直接编辑数据的方式,而非打开一个新的表单进行数据编辑。行内编辑可以提高用户的编辑效率和操作体验,特别是在需要频繁编辑少量数据的场景下。

如何启用 jEasyUI 的行内编辑功能?

要启用 jEasyUI 的行内编辑功能,需要做以下几步:

  1. 引入必要的 CSS 和 JavaScript 文件。可以从官网下载最新版本的 jEasyUI,也可以使用 CDN 网络地址。
htmlCopy Code
<!-- 引入 jEasyUI 的 CSS 文件 --> <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/jquery-easyui@1.9.22/themes/default/easyui.css"> <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/jquery-easyui@1.9.22/themes/icon.css"> <!-- 引入 jQuery 和 jEasyUI 的 JavaScript 文件 --> <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js"></script> <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/jquery-easyui@1.9.22/jquery.easyui.min.js"></script>
  1. 在需要启用行内编辑的表格或列表上添加 class="easyui-datagrid" 属性,并定义相应的列名和数据字段。
htmlCopy Code
<table id="dg" class="easyui-datagrid" style="width:700px;height:250px" url="../datagrid_data.json" title="Data Grid" iconCls="icon-save" toolbar="#toolbar" rownumbers="true" pagination="true" data-options=" singleSelect: true, fitColumns: true "> <thead> <tr> <th field="itemid" width="50">Item ID</th> <th field="productid" width="50" editor="{type:'numberbox',options:{precision:0}}">Product ID</th> <th field="listprice" width="50" align="right" editor="{type:'numberbox',options:{precision:2}}">List Price</th> <th field="unitcost" width="50" align="right" editor="{type:'numberbox',options:{precision:2}}">Unit Cost</th> <th field="attr1" width="150" editor="{type:'validatebox',options:{validType:'email'}}">Attribute</th> <th field="status" width="50" align="center" editor="{type:'checkbox',options:{on:'P',off:''}}">Status</th> </tr> </thead> </table>
  1. 在需要启用行内编辑的列表上添加 class="easyui-datagrid" 属性,定义相应的列名和数据字段,并指定编辑器类型和选项。
javascriptCopy Code
$(function(){ $('#dg').datagrid({ onClickCell: function(index, field, value){ if (field == 'productid'){ $('#dg').datagrid('beginEdit', index); var ed = $('#dg').datagrid('getEditor', {index:index,field:field}); $(ed.target).focus(); } } }); });
  1. 定义表格或列表的 onClickCell 事件,在单元格点击时调用 datagrid('beginEdit', index) 方法启用编辑模式。然后使用 datagrid('getEditor', {index:index,field:field}) 方法获取相应单元格的编辑器实例,对其进行操作即可。

示例

以下是一个使用 jEasyUI 实现行内编辑功能的简单示例,供参考:

htmlCopy Code
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>jEasyUI 行内编辑学习笔记</title> <!-- 引入 jEasyUI 的 CSS 和 JavaScript 文件 --> <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/jquery-easyui@1.9.22/themes/default/easyui.css"> <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/jquery-easyui@1.9.22/themes/icon.css"> <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js"></script> <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/jquery-easyui@1.9.22/jquery.easyui.min.js"></script> <script type="text/javascript"> $(function(){ $('#dg').datagrid({ onClickCell: function(index, field, value){ if (field == 'productid'){ $('#dg').datagrid('beginEdit', index); var ed = $('#dg').datagrid('getEditor', {index:index,field:field}); $(ed.target).focus(); } } }); }); </script> </head> <body> <table id="dg" class="easyui-datagrid" style="width:700px;height:250px" url="../datagrid_data.json" title="Data Grid" iconCls="icon-save" toolbar="#toolbar" rownumbers="true" pagination="true" data-options=" singleSelect: true, fitColumns: true "> <thead> <tr> <th field="itemid" width="50">Item ID</th> <th field="productid" width="50" editor="{type:'numberbox',options:{precision:0}}">Product ID</th> <th field="listprice" width="50" align="right" editor="{type:'numberbox',options:{precision:2}}">List Price</th> <th field="unitcost" width="50" align="right" editor="{type:'numberbox',options:{precision:2}}">Unit Cost</th> <th field="attr1" width="150" editor="{type:'validatebox',options:{validType:'email'}}">Attribute</th> <th field="status" width="50" align="center" editor="{type:'checkbox',options:{on:'P',off:''}}">Status</th> </tr> </thead> </table> </body> </html>