easyUI点击编辑操作实现行编辑,点击取消编辑取消编辑,点击添加实现添加行操作

html 复制代码
<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>EasyUI DataGrid 编辑操作示例</title>
  <!-- 引入 EasyUI 的 CSS 和 JavaScript 文件 -->
  <link rel="stylesheet" type="text/css" href="https://www.jeasyui.com/easyui/themes/default/easyui.css">
  <script type="text/javascript" src="https://www.jeasyui.com/easyui/jquery.min.js"></script>
  <script type="text/javascript" src="https://www.jeasyui.com/easyui/jquery.easyui.min.js"></script>
</head>
<body>
  <!-- 初始化 datagrid 组件 -->
<table id="datagrid"></table>

  <script>
$(function() {
  $('#datagrid').datagrid({
    data:[
  {
    "id": 1,
    "name": "张三",
    "age": 30,
    "gender": "男"
  },
  {
    "id": 2,
    "name": "李四",
    "age": 25,
    "gender": "女"
  },
  {
    "id": 3,
    "name": "王五",
    "age": 40,
    "gender": "男"
  },
  {
    "id": 4,
    "name": "赵六",
    "age": 22,
    "gender": "女"
  },
  {
    "id": 5,
    "name": "孙七",
    "age": 28,
    "gender": "男"
  }
],
    toolbar: [{
      text: '添加',
      iconCls: 'icon-edit',
      handler: function() {
		$('#datagrid').datagrid('insertRow',{
	index: 0,	// index start with 0
	row: {
		name: 'new name',
		age: 30,
		gender: '男'
	}
});
      }
    }],
    columns: [[
      {field:'id', title:'ID', width:100},
      {field:'name', title:'姓名', width:100, editor:'text'},
      {field:'age', title:'年龄', width:100, editor:'numberbox'},
      {field:'gender', title:'性别', width:100, editor:{
        type: 'combobox',
        options: {
          valueField: 'value',
          textField: 'text',
          data: [{value:'男', text:'男'},{value:'女', text:'女'}]
        }
      }},
	              {field:'action',title:'Action',width:100,
                formatter:function(value,row,index){
                    return '<a href="#" onclick="editRow('+index+')">Edit</a> '+' <a href="#" onclick="cancleRow('+index+')">cancle</a>';
                }
            }
    ]],
    onBeforeEdit: function(index, row) {
      row.editing = true;  // 标记行为编辑状态
      $('#datagrid').datagrid('refreshRow', index);  // 刷新行数据
    },
    onAfterEdit: function(index, row) {
      row.editing = false;  // 取消编辑状态
      $('#datagrid').datagrid('refreshRow', index);  // 刷新行数据
    },
    onCancelEdit: function(index, row) {
      row.editing = false;  // 取消编辑状态
      $('#datagrid').datagrid('refreshRow', index);  // 刷新行数据
    }
  });

});
  function editRow(index){
    $('#datagrid').datagrid('beginEdit', index);
}

  function cancleRow(index){
    $('#datagrid').datagrid('cancelEdit', index);
}

  </script>
</body>
</html>
相关推荐
古蓬莱掌管玉米的神6 小时前
vue3语法watch与watchEffect
前端·javascript
林涧泣6 小时前
【Uniapp-Vue3】uni-icons的安装和使用
前端·vue.js·uni-app
雾恋6 小时前
AI导航工具我开源了利用node爬取了几百条数据
前端·开源·github
拉一次撑死狗6 小时前
Vue基础(2)
前端·javascript·vue.js
祯民6 小时前
两年工作之余,我在清华大学出版社出版了一本 AI 应用书籍
前端·aigc
热情仔7 小时前
mock可视化&生成前端代码
前端
m0_748246357 小时前
SpringBoot返回文件让前端下载的几种方式
前端·spring boot·后端
wjs04067 小时前
用css实现一个类似于elementUI中Loading组件有缺口的加载圆环
前端·css·elementui·css实现loading圆环
爱趣五科技7 小时前
无界云剪音频教程:提升视频质感
前端·音视频
qq_544329177 小时前
下载一个项目到跑通的大致过程是什么?
javascript·学习·bug