当前位置: 首页 > news >正文

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分钟内看到完美编辑效果!

http://www.cnnetsun.cn/news/133920.html

相关文章:

  • PCB激光钻孔:CO₂激光VS紫外激光,谁更胜一筹?
  • 数据质量革命:Great Expectations如何重塑企业数据治理格局
  • AI如何帮你快速解决SQL Server连接问题
  • torch.matmul性能优化:比传统方法快10倍的技巧
  • OpenModScan 完全指南:掌握工业自动化调试的必备利器
  • 深度学习压缩技术实战:CompressAI框架的5大核心应用场景
  • 10分钟快速上手:Android离线语音识别的终极解决方案
  • 高效PLC通信框架:S7NetPlus实用开发指南
  • 如何快速上手Semantic UI Calendar:终极前端日期选择器指南
  • 电商平台如何用Kafka工具实现实时订单处理
  • Rustup深度解析:告别版本管理烦恼的终极指南
  • FlyFish:企业级数据可视化的低代码革命
  • RobotGo事件监听:构建智能GUI自动化系统的核心技术
  • 超实用教程:Mikan Project带你轻松玩转动漫资源管理
  • Ubuntu输入法实战:打造个性化中文输入环境
  • 3大核心技巧:充分发挥Windows终端扩展能力
  • 零基础学编程:二维数组的5个简单练习
  • Jupyter AI深度应用:重新定义数据科学工作流的智能化转型
  • 基于鸿蒙的在线学习系统的设计与实现外文翻译
  • 基于回归分析的武当山景点游客流量分析与预测+中期检查报告
  • 秒级验证:Windows Docker环境快速搭建方案
  • 零基础入门:Clash Verge的安装与配置指南
  • 小白也能懂:用快马制作第一个SaaS应用的完整指南
  • cks解题思路-1.32-3
  • Luckysheet数据验证终极指南:告别数据录入错误的完整教程
  • EdgeDeflector终极指南:重夺Windows浏览器选择权
  • 策略模式VS if-else:性能对比实测
  • KlipperScreen触摸屏界面终极安装完整指南
  • 比Docker官方源快10倍:国内镜像源深度测评
  • 【小陈背八股-C++】Day04-大厂面试直击:Vector扩容机制,你真的懂STL容器吗?