关于easyui datagrid 表格中嵌套按钮的做法

这几天刚学会在easyui的datagrid单元格中添加按钮的做法,一路坐下来思路很清晰,不过还是记下来防止以后忘了,毕竟还是没写几遍,不是很熟。下面就是步骤,这个方法应该只是一种还有别的暂且不管,以后看到新的方法再添加。

1.创建easyui-datagrid 表格 代码如下:

<table id="list_data_user" > 
        <thead>
            <tr>
                <th data-options="field:'ck',checkbox:true">用户标识</th>
                <th data-options="field:'userId',width:80">用户标识</th>
                <th data-options="field:'userName',width:80">用户名</th>
                <th data-options="field:'userPermission',width:80" >用户类型</th>
                <th data-options="field:'userCreateTime',width:80,formatter:Common.TimeFormatter">创建时间</th>
                <th data-options="field:'userUpdateTime',width:80,formatter:Common.TimeFormatter">更新时间</th>
                <th data-options="field:'_operate',width:80,align:'center',formatter:formatOper">操作</th>
                
            </tr>
        </thead>
    </table>
    <script>
        $(function() {
            $('#list_data_user').datagrid({ 
               
                iconCls:'icon-edit',//图标 
                width: 500, 
                height: 'auto', 
                nowrap: false, 
                striped: true, 
                border: true, 
                collapsible:false,//是否可折叠的 
                fit: true,//自动大小 
                fitColumns: true,//列宽自适应 
                loadMsg: '数据加载中请稍后……',
                url:'../ra/userservice/getlist', 
                method:'get',
                remoteSort:false,  
                idField:'userId', 
                singleSelect:false,//是否单选 
                pagination:true,//分页控件 
                rownumbers:false,//行号 
                onLoadSuccess: function () {
                    $('.easyui-linkbutton_promote').linkbutton({
                        text : '设为管理员',
                        plain : true,
                        iconCls : 'icon-ok'
                    }),
                    $('.easyui-linkbutton_del').linkbutton({
                        text : '删除',
                        plain : true,
                        iconCls : 'icon-no'
                    });
                    
                    
                },  
                onLoadError: function() {
                    alert("list_data_syslog datagrid onLoadError");
                },
                toolbar:[{
                    text:'删除',
                    iconCls : 'icon-no',
                    handler : function() {
                         UserTabUtil.deleterows();          
                    }
                }]
            }); 
        });

上面代码中是将按钮凡在了操作一列上,通过formatter来格式化达到嵌入按钮的效果。既然格式化调用了这个formatOper方法,那我们需要写一个该方法定义一个按钮,从上面的代码也可以看出,定义的按钮在onLoadSuccess(){}里面呈现。

2.创建formatOper方法 代码如下:

function formatOper(value, row, index) {

            var str = "";
            //按钮是esayui-linkbutton 需要拼接出来,这年头拼接传参数简直要人老命
            var promoteBtnObj = '<a class="easyui-linkbutton_promote"onclick="UserTabUtil.userPromote('+row.userId+')"></a>';
            var delBtnObj = '<a class="easyui-linkbutton_del" onclick="UserTabUtil.deleterow('
                    + row.userId + ')"></a>';
                    
                    
            str += promoteBtnObj;
            str += delBtnObj;
            

            return str;
        }

从上面代码可以看出之前onLoadSuccess(){}里定义的就在这拼接出来,可以看到按钮里有onclick方法,所以我们还需要的是onclick可以调用的触发方法,也就是我们这个按钮要实现的功能所要调用的终极无敌大招,这个方法就看你的需求了上面只是调用这个方法。
但是目前调用的还不是直接调用我们的终极无敌大招,上面的onclick调用的是下面代码定义的一个方法,看代码:

<script type="text/javascript">
        UserTabUtil = {
                deleterow : function (userId) {
                      $.messager.confirm("操作提示","确定删除?",function(r){
                         if(r){
                            DBExector.deleteUser(userId);
                             
                         } 
                    
                      });   
                    },
                     deleterows : function(){
                          $.messager.confirm("操作提示", "确定删除?", function(r) {
                            if(r){
                                var rows = $('#list_data_user').datagrid('getSelections');
                                var resultArr = [];
                                for(var i=0;i < rows.length;i++){
                                    resultArr[i] = rows[i].userId;
                                }
                                var resultIds = StringUtils.spiltByTag(resultArr, ",");
                                DBExector.deleteUser(resultIds);
                            }
                        });
                      },
                     userPromote :function(userId){
                         $.messager.confirm("操作提示","确定升级为管理员",function(r){
                             if(r){
                                 DBExector.updataPromote(userId);
                             }
                         });
                     } 
        };
         
    </script>

哎 从上面的代码就可以看出来了 这些方法才是最后的调用。通过这个方法调用到与后台数据联系的方法,有很多写的方法 ,我只是觉得这样写比较拉风,便于装逼。

上面的就是在easyui-datagrid中嵌套按钮的一种方法,方法应该还有很多,不过我暂时只会这一个还是偷学来的 ,先记录下来,以后发现别的方法再补充进来。

记下爬过的坑防止忘了又掉坑里。第一篇自己的原创简书,好6啊哈哈,我要走向宗师了,加油。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,825评论 25 707
  • 1.从载入EasyUI开始 读者需要到EasyUI官网中下载包含原文件和demo的压缩包,并解压到之前编写的代码目...
    老皮丘阅读 1,700评论 0 6
  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 7,727评论 2 17
  • 谈谈风气 现在这个社会是个快速发展的阶段,而中国先如今是更迅速发展,2015年全球收益达383亿美元,其中中国达6...
    雨过天晴L阅读 404评论 3 0
  • 嗯~要走了,有点不舍! 还记得来到店里之后,彩霞姐是第一个对我笑的女孩,谢谢你的微笑,让我觉得不那么孤单!一直相信...
    卓雅angel阅读 465评论 0 0