首页 > 代码库 > easyui学习笔记2—在行内进行表格的增删改操作【转载】

easyui学习笔记2—在行内进行表格的增删改操作【转载】

第一篇笔记中记录了如何实现表格的增删改,那个是点击之后跳出来一个对话框然后进行的,这里是在表格本身上进行的操作,也很简单,但是这里发现一个版本问题,也可以说是兼容性问题。

1.首先我们看引用的js和css代码

<link rel="stylesheet" href="http://www.mamicode.com/jquery-easyui-1.3.5/themes/default/easyui.css" />        <link rel="stylesheet" href="http://www.mamicode.com/jquery-easyui-1.3.5/themes/icon.css" />        <link rel="stylesheet" href="http://www.mamicode.com/jquery-easyui-1.3.5/demo/demo.css"/>        <script type="text/javascript" src="http://www.mamicode.com/jquery-easyui-1.3.5/jquery-1.10.2.min.js"></script>        <script type="text/javascript" src="http://www.mamicode.com/jquery-easyui-1.3.5/jquery.easyui.min.js"></script>        <script type="text/javascript" src="http://www.mamicode.com/jquery-easyui-1.3.5/easyui/plugins/jquery.edatagrid.js"></script>

这里和上一篇比较而言新增加了一个<script type="text/javascript" src="http://www.jeasyui.com/easyui/jquery.edatagrid.js"></script>这个是修改表格时用到的,可是我在下载的源文件中就是找不到这个js文件呢,在里面有个类似的文件D:\Serious\phpdev\easyui \jquery-easyui-1.3.5\plugins/jquery.datagrid.js这个,看上去有点类似,但是少个字母“e”,纳闷了到底是jquery.datagrid.js还是jquery.edatagrid.js呢?你可能已经注意到我这里下载的最新的easyui版本 jquery-easyui-1.3.5,是版本更新么?先不管他,继续往下看了。

2.然后是html代码,先定义一个表格,如下:

<table id="dg" title="My User" style="" style="width:700px;height:250px" toolbar="#toolbar" pagination="true" idField="id" rownumbers="true" fitColumns="true" singleSelect="true">                <thead>                    <th field="firstname" width="50" editor="{type:‘validatebox‘,options:{required:true}}">First Name</th>                    <th field="lastname" width="50" editor="{type:‘validatebox‘,options:{required:true}}">Last Name</th>                    <th field="phone" width="50" editor="text">Phone</th>                    <th field="email" width="50" editor="{type:‘validatebox‘,options:{validType:‘email‘}}">Email</th>                </thead>            </table>

注意toolbar的命名要和下面定义的工具栏对应,idField="id"这个应该是定义这一行的主键,在做删除操作的时候用到这个主键,在列名的定义中我们可以看到
editor="{type:‘validatebox‘,options:{required:true}}"这样的一句,字面意义上应该是可编辑的且需要验证的,验证规则是必填的。editor="text"这个就应该是简单的文本信息不需要验证的,不是必填的。editor="{type:‘validatebox‘,options:{validType:‘email‘}}" 这个应该也是必填的且验证规则是email验证。

3.下面看工具栏是如何定义的

<div id="toolbar">                <a href="javascript:void(0)" class="easyui-linkbutton" iconCls="icon-add" plain="true" onclick="jvascript:$(‘#dg‘).edatagrid(‘addRow‘)">New</a>                <a href="javascript:void(0)" class="easyui-linkbutton" iconCls="icon-remove" plain="true" onclick="jvascript:$(‘#dg‘).edatagrid(‘destroyRow‘)">Destory</a>                <a href="javascript:void(0)" class="easyui-linkbutton" iconCls="icon-save" plain="true" onclick="jvascript:$(‘#dg‘).edatagrid(‘saveRow‘)">Save</a>                <a href="javascript:void(0)" class="easyui-linkbutton" iconCls="icon-undo" plain="true" onclick="jvascript:$(‘#dg‘).edatagrid(‘cancelRow‘)">Cancel</a>            </div>

这个就是定义增,删,改的操作的onclick="jvascript:$(‘#dg‘).edatagrid(‘addRow‘)"这个很很明显就是新增一行,效果如下图1

图1

4.最后我们看看js代码

$(function(){        $(‘#dg‘).edatagrid({        url: ‘get_users.php‘,        saveUrl: ‘save_user.php‘,        updateUrl: ‘update_user.php‘,        destroyUrl: ‘destory_user.php‘        });    });    </script>

就这么几行,这里只是指定了对应的动作url,估计jquery.edatagrid.js这个js里面会处理对应的操作规则。

最后就是我发现使用本地的jquery-easyui-1.3.5/easyui/plugins/jquery.datagrid.js这个文件是会报错的,各种各样的错误,使用官网上给的那个文件是可以的,就是引用<scripttype="text/javascript"src="http://www.jeasyui.com/easyui/jquery.edatagrid.js"></script>这个文件。不知道各位有没有注意到这个让人蛋疼的问题。还有这里工具栏中没有给出编辑的按钮,而是双击需要编辑的行,对应的行就会变成可编辑状态,然后点击Save按钮就可以正常保存,这个对我们来说有点抓瞎的,如果某一列不需要编辑呢。

via:http://www.cnblogs.com/tylerdonet/p/3516614.html