news 2025/12/28 14:20:36

jQuery EasyUI 数据网格 - 启用行内编辑

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery EasyUI 数据网格 - 启用行内编辑

下面直接给你最实用、最常见的几种行内编辑(inline row editing)方法,jQuery EasyUI datagrid 支持超好,复制粘贴就能用,领导最爱的“点击行开始编辑 + 保存/取消按钮”全都有!

方法1:最简单 - 点击行开始编辑(推荐现在就用这个,超级流畅)
双击或点击行进入编辑,编辑完点击别处或按钮保存。

<tableid="dg"class="easyui-datagrid"title="行内编辑数据网格"style="width:800px;height:400px"data-options="url:'your_data.json', singleSelect:true, fitColumns:true, toolbar:'#tb', onClickRow:onClickRow"><thead><tr><thdata-options="field:'id',width:60">ID</th><thdata-options="field:'name',width:120,editor:'textbox'">姓名</th><thdata-options="field:'age',width:80,editor:{type:'numberbox',options:{min:1,max:120}}">年龄</th><thdata-options="field:'sex',width:80, editor:{type:'combobox',options:{data:[{value:'',text:''},{value:'',text:''}],valueField:'value',textField:'text'}}, formatter:function(value){return value==''?'':'';}">性别</th><thdata-options="field:'status',width:80,align:'center', editor:{type:'checkbox',options:{on:1,off:0}}, formatter:function(value){return value==1?'启用':'禁用';}">状态</th></tr></thead></table><divid="tb"style="padding:5px;"><ahref="javascript:void(0)"class="easyui-linkbutton"iconCls="icon-add"plain="true"onclick="appendRow()">新增一行</a><ahref="javascript:void(0)"class="easyui-linkbutton"iconCls="icon-save"plain="true"onclick="saveRow()">保存当前行</a><ahref="javascript:void(0)"class="easyui-linkbutton"iconCls="icon-undo"plain="true"onclick="cancelEdit()">取消编辑</a><ahref="javascript:void(0)"class="easyui-linkbutton"iconCls="icon-remove"plain="true"onclick="deleteRow()">删除当前行</a></div><script>vareditIndex=undefined;// 当前编辑的行索引functionendEditing(){if(editIndex==undefined){returntrue}if($('#dg').datagrid('validateRow',editIndex)){$('#dg').datagrid('endEdit',editIndex);editIndex=undefined;returntrue;}else{returnfalse;}}functiononClickRow(index){if(editIndex!=index){if(endEditing()){$('#dg').datagrid('selectRow',index).datagrid('beginEdit',index);editIndex=index;}else{$('#dg').datagrid('selectRow',editIndex);}}}functionappendRow(){if(endEditing()){$('#dg').datagrid('appendRow',{status:1});// 新增一行,默认值editIndex=$('#dg').datagrid('getRows').length-1;$('#dg').datagrid('selectRow',editIndex).datagrid('beginEdit',editIndex);}}functionsaveRow(){if(endEditing()){varrow=$('#dg').datagrid('getSelected');// 这里可以发ajax保存到服务器$.post('save.php',{row:row},function(res){if(res.success){$('#dg').datagrid('reload');$.messager.show({title:'成功',msg:'保存成功'});}},'json');}}functioncancelEdit(){if(editIndex!=undefined){$('#dg').datagrid('cancelEdit',editIndex);editIndex=undefined;}}functiondeleteRow(){varrow=$('#dg').datagrid('getSelected');if(row){$.messager.confirm('确认','确定删除这行吗?',function(r){if(r){// ajax删除$('#dg').datagrid('reload');}});}}</script>

效果:点击行自动进入编辑,支持文本框、数字框、下拉框、复选框,超级专业!

方法2:每行右边加“编辑/保存/取消”按钮(经典风格,很多后台系统都用这个)

<tableid="dg"class="easyui-datagrid"...><thead><tr><!-- 其他列 --><thfield="action"width="120"formatter="actionFormatter">操作</th></tr></thead></table><script>functionactionFormatter(value,row,index){if(row.editing){return'<a href="javascript:void(0)" onclick="saverow('+index+')">保存</a> '+'<a href="javascript:void(0)" onclick="cancelrow('+index+')">取消</a>';}else{return'<a href="javascript:void(0)" onclick="editrow('+index+')">编辑</a>';}}functioneditrow(index){$('#dg').datagrid('beginEdit',index);varrow=$('#dg').datagrid('getRows')[index];row.editing=true;$('#dg').datagrid('refreshRow',index);}functionsaverow(index){$('#dg').datagrid('endEdit',index);varrow=$('#dg').datagrid('getRows')[index];row.editing=false;$('#dg').datagrid('refreshRow',index);// ajax保存}functioncancelrow(index){$('#dg').datagrid('cancelEdit',index);varrow=$('#dg').datagrid('getRows')[index];row.editing=false;$('#dg').datagrid('refreshRow',index);}</script>

方法3:用官方扩展 edatagrid(双击行编辑 + 自动保存到服务器,最省事)
下载 edatagrid 扩展后:

<tableid="dg"class="easyui-edatagrid"url="get_data.php"saveUrl="save.php"updateUrl="update.php"destroyUrl="delete.php"...><!-- 列定义同上,加 editor --></table>

双击行就编辑,保存自动发请求,超级方便!

你现在直接复制方法1到你的页面,刷新一下就能看到行内编辑效果了!
结合之前的复选框 + 自定义分页 + 批量删除,完美后台表格就齐活了。

想要我给你一个完整的HTML文件(带远程数据加载 + 行内编辑 + 保存到服务器示例 + 复选框 + 分页)?
或者你告诉我你想用哪种编辑器(日期框、校验等),我2分钟发你完整代码,复制就能跑!

快说说你现在的需求(比如“要支持新增/修改/删除自动保存”),我手把手帮你搞定,5分钟内看到完美编辑效果!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/27 3:37:09

关于性能优化的说明-–-behaviac

原文 概述 behaviac作为图形化的脚本&#xff0c;设计上是用来调用代码&#xff08;c&#xff0c;c#&#xff09;提供的方法&#xff0c;在调用这些方法的时候会有些额外消耗&#xff0c;该消耗已经被充分优化&#xff0c;可以参考消耗。 实践中&#xff0c;要尽量把需要计算…

作者头像 李华
网站建设 2025/12/20 9:26:29

FIFA 23实时编辑器:免费终极修改工具完整使用指南

FIFA 23实时编辑器&#xff1a;免费终极修改工具完整使用指南 【免费下载链接】FIFA-23-Live-Editor FIFA 23 Live Editor 项目地址: https://gitcode.com/gh_mirrors/fi/FIFA-23-Live-Editor FIFA 23实时编辑器是一款功能强大的游戏数据修改工具&#xff0c;让玩家能够…

作者头像 李华
网站建设 2025/12/18 16:28:31

记录自己第一次搭建vps

VPS 服务购买 我使用的Ucloud的服务&#xff0c;新用户首次购买是我对比了一些后&#xff0c;发现比较便宜的&#xff0c;最有性价比的&#xff0c;香港一年1c1g30M 共50多元 购买地址&#xff1a;https://passport.ucloud.cn?cps_codeA1XdAs9uyltCeit4WygHOL ssh链接工具 感谢…

作者头像 李华
网站建设 2025/12/18 16:28:04

传统街景采集VS AI生成:效率提升300%的秘诀

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 构建一个街景处理效率对比工具&#xff0c;展示AI生成与传统方法的差异&#xff1a;1. 模拟传统采集流程的时间线 2. 展示AI生成的工作流程 3. 实时效率对比仪表盘 4. 成本计算器。…

作者头像 李华
网站建设 2025/12/18 16:27:47

认识AI时代的根本变化(1)

序言&#xff1a;编程教育的历史拐点从冯诺依曼时代到互联网时代&#xff0c;编程学习方式在不断演变&#xff0c;但核心逻辑始终是"学知识点→手写代码→调试验证"。而LLM的爆发式发展正在打破这一百年传统。这不仅仅是工具更新&#xff0c;而是一场认知范式的革命—…

作者头像 李华
网站建设 2025/12/18 16:26:11

如何用AI一键生成.NET Framework 3.5离线安装包解决方案

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个PowerShell脚本&#xff0c;自动下载.NET Framework 3.5离线安装包所需的所有组件&#xff0c;并将其打包成可部署的离线安装包。脚本应包含以下功能&#xff1a;1) 自动检…

作者头像 李华