easyui datagrid 工具栏实现方式

在使用datagrid时,工具栏有时需要动态控制或添加一些自定义的内容进去,这里把用到的总结一下。

第一种:先定义,后追加

前四个按钮使用datagrid的属性方式添加:

     toolbar: [
                { text: '增加', iconCls: 'icon-add', handler: function () { deviceInfoAddClick(); } },
                { text: '修改', iconCls: 'icon-edit', handler: function () { deviceInfoEditClick(); } },
                { text: '删除', iconCls: 'icon-remove', handler: function () { deviceInfoDeleteClick(); } },
                { text: '查看', handler: function () { } }, '-',
                { text: '刷新', iconCls: 'icon-reload', handler: function () { deviceInfoRefreshClick(); } },
                { text: '导出', iconCls: 'icon-save', handler: function () { $(dg).treegrid('reload'); } }, '-'],

最后面的那个搜索框就不能这么简单的添加进去了。需要先在前台定义好:

    <%--下拉搜索框--%>
    <div id="searchboxWrapper" style="display: inline-block; padding-top: 3px; text-align: right;
         200px;">   
        <input id="searchbox" class="easyui-searchbox" searcher="searcherFun" prompt="请输入查询内容"
            style=" 200px; margin-top: 10px; padding-top: 10px;"></input>
        <div id="mm" style=" 100px">
        </div>
    </div>

在datagrid初始化之后,初始化下拉搜索框并追加到原来的工具栏后面。

    $(function () {
            initDatagrid();
            initSearchbox();
            });
        function initSearchbox() {
            /// <summary>初始化下拉搜索框</summary>
            //循环列名,生成搜索的下拉列表
            var fields = $(dg).datagrid('getColumnFields');
            var muit = "";
            for (var i = 0; i < fields.length; i++) {
                var opts = $(dg).datagrid('getColumnOption', fields[i]);
                if (opts.table) {
                    muit += "<div name='" + opts.table + "." + opts.column + "'>" + opts.title + "</div>";
                } else {
                    muit += "<div name='" + fields[i] + "'>" + opts.title + "</div>";
                }
            };
            $('#mm').html($('#mm').html() + muit);
            $('#searchbox').searchbox({
                menu: '#mm'
            });
            //将生成好的搜索框放入工具栏
            $(".datagrid-toolbar").append($("#searchboxWrapper"));
        }

首先循环列名填充下拉搜索框,然后实例化,最后追加到工具栏后面。 因为有些数据是通过多表联合查询得出来的数据,这样在使用下拉框定义搜索条件时必须指定好要查询的表名和列名,我这里使用table和column两个属性指定

         { title: 'SmartIO', field: 'SmartIoName', table: 'Dev_SmartIO', column: 'Name',  80, hidden: false },
                    { title: 'pSpace', field: 'PspaceName', table: 'Dev_pSpace', column: 'Name',  80, hidden: false },

后台使用IBatis查询数据,其中有个方法是直接传入where语句

    <select id="FindAllBySearchKey" resultMap="ResultMap"  parameterClass="string"   >
      SELECT *,Dev_SmartIO.Name as SmartIoName,Dev_pSpace.Name as PspaceName,Dev_Teamplate.Name as DevTeamplateName
      FROM [dbo].[Dev_DeviceInfo]  left join dbo.Dev_SmartIO  on [Dev_DeviceInfo].SmartIoID=Dev_SmartIO.ID  left join dbo.Dev_pSpace  on [Dev_DeviceInfo].PspaceID=Dev_pSpace.ID  left join dbo.Dev_Teamplate  on [Dev_DeviceInfo].DevTeamplateID=Dev_Teamplate.ID
      where $value$ and  [IsDeleted] =0
    </select>

在表联合时我没有使用别名,所以在where条件里也是直接使用原表名.列名既可。 这就与前端生成的过滤字段一致了。
点击搜索按钮会执行 searcherFun 方法。

      function searcherFun(value, name) {
            /// <summary>搜索列表</summary>
            loadData(name, value)
        }
   function loadData(searchKey, searchValue) {
            /// <summary>加载数据</summary>
            var url = 'http://www.cnblogs.com/AjaxHandler/DevDeviceInfoHandler.ashx?action=DeviceInfoList&tmp=' + Math.random().toString();
            if (searchKey != null)
                url += "&searchKey" + searchKey + "$searchValue" + searchValue;
            $(dg).datagrid('options').url = url;
        }

设置完url后就会自动去后台加载数据,并把当前的分页信息也带过去。

    /// <summary>
    /// 设备列表
    /// </summary>
    public bool DeviceInfoList()
    {
        EasyUI_datagrid grid = new EasyUI_datagrid();
        try
        {
            string searchKey = this.Context.Request["searchKey"];
            string searchValue = this.Context.Request["searchValue"];
            string page = Context.Request["page"];
            string rows = Context.Request["rows"];

            List<Dev_DeviceInfo> list = DevService.GetInstance().FindAllDeviceInfoList(searchKey, searchValue, page, rows) as List<Dev_DeviceInfo>;

            grid.total = DevService.GetInstance().GetCountDeviceInfoList(searchKey, searchValue);
            list.ForEach(q => grid.AddRows(q));
            grid.success = true;
            return true;
        }
        catch (Exception ex)
        {
            grid.success = false;
            grid.msg = ex.Message;
            return false;
        }
        finally
        {
            this.Context.Response.Write(JsonConvert.SerializeObject(grid));
        }
    }

这里需要注意的是返回的数据需要是datagrid需要的格式,即有total和rows两个属性。扯远了,把数据的来龙去脉都写了,呵呵。
第二种:直接在前台定义div,使用toolbar属性指向

工具栏需要使用下拉菜单,默认方式也不好弄,所以这里使用html代码定义好。

     <%--测点工具栏--%>
                    <div id="pointDatagridToolbar">
                        <a href="javascript:void(0)" id="Add">添加</a> <a href="javascript:void(0)" id="Edit"
                            onclick="TagEditClick()">修改</a><a href="javascript:void(0)" id="Del" onclick="TagDeleteClick()">删除</a>
                        <div id="AddMenu" style=" 100px;">
                            <div onclick="TagAddClick('MNL')">
                                模拟量</div>
                            <div onclick="TagAddClick('KGL')">
                                开关量</div>
                            <div onclick="TagAddClick('ZFCL')">
                                字符串量</div>
                        </div>
                    </div>
//初始化菜单
function InitMenubutton() {
    $('#Add').menubutton({
        menu: '#AddMenu',
        iconCls: 'icon-add',
        plain: true
    });

    $('#Edit').linkbutton({
        iconCls: 'icon-edit',
        plain: true
    });

    $('#Del').linkbutton({
        iconCls: 'icon-remove',
        plain: true
    });
}
       toolbar: "#pointDatagridToolbar",

这种方式最灵活了,排版布局方便。使用这个还走过一个弯路,就是顶一个一个两行的table,第一行放工具栏,第二行行datagrid,看起来也很像是一体的。

 

最后一个按钮靠右对齐,使用了table布局方式,div的我搞不出来。

 <%--工具栏--%>
    <div id="dev_deviceInfo_toolbar" class="datagrid-toolbar">
        <table border="0" cellpadding="0" cellspacing="0" style=" 100%;">
            <tr>
                <td style=" 700px;">
                    <%--正常的设备列表--%>
                    <div id="normal">
                        <div style="float: left; padding: 0px; height: auto">
                            <a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-add',plain:true"
                                onclick="deviceInfoAddClick();">增加</a> <a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-edit',plain:true"
                                    onclick="deviceInfoEditClick();">修改</a><a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-remove',plain:true"
                                        onclick="deviceInfoDeleteClick();">删除</a><a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-remove',plain:true"
                                            onclick="deviceInfoDirectDeleteClick();">彻底删除</a>
                        </div>
                        <%--分割线--%>
                        <div id="separator" style="float: left;" class="datagrid-btn-separator">
                        </div>
                        <div style="float: left; padding: 0px; height: auto">
                            <a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-add',plain:true"
                                onclick="deviceInfoViewClick();">查看</a> <a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-reload',plain:true"
                                    onclick="deviceInfoRefreshClick();">刷新</a>
                        </div>
                        <div id="Div1" style="float: left;" class="datagrid-btn-separator">
                        </div>
                        <%--下拉搜索框--%>
                        <div id="searchboxWrapper" style="display: inline-block; padding-top: 3px; text-align: left;
                             200px;">
                            <input id="searchbox" class="easyui-searchbox" searcher="searcherFun" prompt="请输入查询内容"
                                style=" 200px; margin-top: 10px; padding-top: 10px;"></input>
                            <div id="mm" style=" 100px">
                            </div>
                        </div>
                    </div>
                    <%--已删除的设备--%>
                    <div id="deleted" style="display: none;">
                        <div style="float: left; padding: 0px; height: auto">
                            <a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-edit',plain:true"
                                onclick="deviceInfoDirectDeleteClick();">彻底删除</a><a href="#" class="easyui-linkbutton"
                                    data-options="iconCls:'icon-remove',plain:true" onclick="deviceInfoViewClick();">查看</a><a
                                        href="#" class="easyui-linkbutton" data-options="iconCls:'icon-back',plain:true"
                                        onclick="deviceInfoBackClick();">返回</a>
                        </div>
                    </div>
                </td>
                <td style="text-align: right;">
                    <a href="#" class="easyui-linkbutton" data-options="iconCls:'icon-hsz-16-16',plain:true"
                        onclick="deviceInfoDeletedClick();">回收站</a>
                    <%--      <div style="display: inline-block; padding-top: 3px; text-align: right;  300px;">
                       
                    </div>--%>
                </td>
            </tr>
        </table>
    </div>
原文地址:https://www.cnblogs.com/zhaobl/p/2881097.html