利用BootStrap Table插件实现自己的弹出框分页。

参考链接1:
    官网:http://bootstrap-table.wenzhixin.net.cn/zh-cn/home/
        开始使用:http://bootstrap-table.wenzhixin.net.cn/zh-cn/getting-started/
        文档:http://bootstrap-table.wenzhixin.net.cn/zh-cn/documentation/
    参考链接2:https://www.cnblogs.com/wlandwl/p/bootstrap_table.html

1、第一步、首先,先将基本数据信息以table分页展示的出来。(即非弹出框分页的数据,以table分页的方式展示出来)。

 1 <div style="width:100%; padding: 10px;">
 2     <table id="tablewrap1"
 3        data-toggle="table"
 4        data-locale="zh-CN"
 5        data-ajax="ajaxRequest"
 6        data-single-select="true"
 7        data-side-pagination="server"        //服务端分页设置:在配置文件中设置分页方式为服务器分页。 分页方式:client客户端分页,server服务端分页(*)
 8        data-striped="true"                  //设置为 true 会有隔行变色效果。
 9        data-pagination="true"               //是否支持分页
10        data-pagination-first-text="首页"
11        data-pagination-pre-text="上一页"
12        data-pagination-next-text="下一页"
13        data-pagination-last-text="末页" class="fline-show-when-ready"
14        data-show-jumpto="true">
15          <thead>
16           <tr>
17             <th data-field="id" data-formatter="idFormatter" data-width="40">xx编号</th>
18             <th data-field="name">xx名称</th>
19             <th data-field="code">xx性别</th>
20             <th data-field="accessType" data-formatter="formatAccessType">xx年龄</th>
21             <th data-field="versionTag">xx生日</th>
22             <th data-field="updateDate" data-formatter="formatDate">xx时间</th>
23             <th data-field="status" data-formatter="formatStatus">xx地址</th>
24             <th data-field="operate" data-formatter="opFormatter">xx操作</th> 
25          </tr>
26         </thead>
27     </table>
28 </div>

2、第二步、先将基本数据信息以table分页展示的出来,使用的ajax将数据查询出来,在上面所示的table展示出来。

 1 function ajaxRequest(params) {
 2     var pageSize = params.data.limit;
 3     var pageNum = params.data.offset/pageSize + 1;
 4     index = params.data.offset + 1;
 5     var sort = params.data.sort? params.data.sort : "id";
 6     var order = params.data.order? params.data.order : "desc";
 7     var datas;
 8     var items;
 9     $.ajax({
10         type:'POST',
11         url:'xxxAction!selectStudent.action?pageNum=' + pageNum + '&pageSize=' + pageSize,
12         dataType:'json',
13         async:true,
14         data:$('#searchForm').serialize(),
15         error: function(request, textStatus, errorThrown) {
16             fxShowAjaxError(request, textStatus, errorThrown);
17         },
18         success:function(data){
19             datas = data.result;
20             if(datas != null) {
21                 count = datas.count;
22             }
23             items = datas.items?datas.items:[];
24             params.success({
25                 total: count,
26                 rows: items
27             });
28             params.complete();
29         }
30     });
31 }

3、第三步、第一步<th data-field="operate" data-formatter="opFormatter">xx操作</th> 可以使用如下的方法,点击xx操作的,然后可以弹出弹出框分页信息。

 1 function opFormatter(value,row) {
 2     var tmp="'"+row.code+"'";
 3     var name="'"+row.name+"'";
 4     return '<a href="javascript:void(0)" onclick="getxxxDetails('+tmp+","+name+')">点击弹出框分页</a>';
 5 }
 6 
 7 如下是弹出框的确定和关闭。
 8 function getxxxDetails(code,name){
 9     $("#tablewrap2").bootstrapTable("selectPage",1);
10     initCatalogTable(code);
11     $("#tenantCatalogTablediv").dialog({
12         title : name+"xxx",
13         width : "900",
14         'class' : "mydialog",
15         onClose : function() {
16             $(this).dialog("close");
17         }
18         ,buttons : {
19             "关闭" : function() {
20                 $(this).dialog("close");
21             }
22         }
23     });
24 }

4、第四步、弹出框分页的table如下所示。

 1 <div style="display: none;">
 2     <div style="width: 850; padding-top: 8px;" align="left" id="tenantCatalogTablediv" >
 3         <table id="tablewrap2"
 4                data-toggle="table"
 5                data-locale="zh-CN"
 6                data-single-select="true"
 7                data-click-to-select="false"
 8                data-side-pagination="client" //服务端分页设置:在配置文件中设置分页方式为服务器分页。 分页方式:client客户端分页,server服务端分页(*)
 9                data-striped="true"
10                data-pagination="true"
11                data-pagination-first-text="首页"
12                data-pagination-pre-text="上一页"
13                data-pagination-next-text="下一页"
14                data-pagination-last-text="末页"
15                >
16             <thead>
17                 <tr>
18                     <th data-field="url" data-formatter="paramsMatter">xx地址</th>
19                     <th data-field="resultCode" >xx姓名</th>
20                     <th data-field="resultMsg" data-formatter="paramsResultMsgr">xx性别</th>
21                     <th data-field="createTime" data-formatter="formatDate">xx年龄</th>
22                 </tr>
23             </thead>
24         </table>
25     </div>
26 </div>

5、第五步、第四步弹出框分页的table使用如下ajax加载出数据。进行Bootstrap Table 数据绑定。

 1 function initCatalogTable(code){
 2     $.ajax({
 3         type : "POST",
 4         url : 'xxxAction!selectTeacher.action',
 5         data : {'code' : code},
 6         async : false,
 7         error : function(request, textStatus,errorThrown) {
 8             fxShowAjaxError(request, textStatus,errorThrown);
 9         },
10         success : function(data) {
11             data=data.result;
12             if(data==null){
13                 $("#tablewrap2").bootstrapTable('load', []);
14                 return;
15             } 
16             $('#tablewrap2').bootstrapTable('load', data);
17         }
18     });
19 }

 

待续......

posted on 2018-12-20 15:41  别先生  阅读(1992)  评论(1编辑  收藏  举报