两种表格工具,今天都用到了,一种是我前几篇写到过的jqgrid,(传送门)另一个就是bootstrap-table了。用过之后会发现,两种表格的方式大同小异,但是为什么这次要换成bootstrap-table呢,是因为我们在写树形结构,由于jqgrid 的树形结构的数据结构和字段要求的太多的,导致了后台再提供数据的时候需要格式化(实话实说,这个要求的有点多),如果有兴趣,大家可以看我这篇博客(传送门)。所以,我们决定使用bootstrap-table的树形结构来结果这个问题。引入css和js文件是第一步,这里我放cdn地址,如果失效了,大家请自行下载

 <link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
<link href="https://cdn.bootcss.com/bootstrap-table/1.11.1/bootstrap-table.min.css" rel="stylesheet">
<link href="https://cdn.bootcss.com/jquery-treegrid/0.2.0/css/jquery.treegrid.min.css" rel="stylesheet"> //树形结构的文件,如果没有用到,请删除
<script src="https://cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>
<script src="https://cdn.bootcss.com/bootstrap-table/1.12.1/bootstrap-table.min.js"></script>
<script src="https://cdn.bootcss.com/bootstrap-table/1.12.0/extensions/treegrid/bootstrap-table-treegrid.js"></script> //树形结构的文件,如果没有用到,请删除
<script src="https://cdn.bootcss.com/jquery-treegrid/0.2.0/js/jquery.treegrid.min.js"></script> //树形结构的文件,如果没有用到,请删除

  首先是利用bootstrap-table来加载数据。然后只需要设置几个基本的“idField”,“treeShowField”,“parentIdField”字段就可以得到树形接口,非常的简单,不多说,直接放代码:

  $table = $("一个table标签的id");

         $table.bootstrapTable({
url: base_url + '/Gamecharm/show.php',//接口地址
//url: "__ROOT__/public/js/data.json",//我本地测试的接口地址
method:"get",//接口地址获取的方式,post或者get
//data:data,//如果是我们自己用ajax获取数据,或者说数据就是本地的,需要放在这里
idField: 'id',//父元素的标识,这里我们使用的是id
pageNumber:1,//默认第几页
responseHandler:function(res) { //这个其实是和jqgrid中的jsonReader ,就是说bootstrap中和jqgrid一样,都有默认的字段,如果后台给我们的不是默认的,所以就需要我们自己更改 如果还是不明白,请看链接 return {
"data": res.datas //主数据
//"total": res.result.total
};
},
queryParams:{ //传参这个和jqgrid中的postData是一样的,就是接口请求的参数
"creatTime":getdate()
},
columns: [ //下面是格式化数据
{
field: 'id', //需要的字段id
title: '日期', //列名称
},
{
field: 'h',
title: '商户名',
},
{
field: 'game_id',
title: '游戏名',
formatter:function(cellvalue){
var str = "";
for(var i =0;i<game_type_arr.length;i++){
if(cellvalue == game_type_arr[i]["game_id"]){
str = game_type_arr[i]["game_name"];
return str;
}
}
return str;
}
},
{
field: 'h',
title: '玩家数',
},
{
field: 'rounds',
title: '游戏局数',
},
{
field: 'bets',
title: '投注金额',
formatter:function(cellvalue){
return (cellvalue/10000).toFixed(4);
}
},
{
field: 'effects',
title: '有效投注量',
formatter:function(cellvalue){
return (cellvalue/10000).toFixed(4);
}
},
{
field: 'total_revenue',
title: '中奖金额',
formatter:function(cellvalue){
return (cellvalue/10000).toFixed(4);
}
},
{
field: 'fees',
title: '房费',
formatter:function(cellvalue){
return (cellvalue/10000).toFixed(4);
}
},
{
field: 'total_win_agent',
title: '商户盈亏',
formatter:function(cellvalue){
return (cellvalue/10000).toFixed(4);
}
},
{
field: 'rtp',
title: 'RTP(%)',
formatter:function(cellvalue,rowObject){ //自己格式化数据;这里需要注意的是,他的参数顺序和jqgrid不太一样,需要注意
var str ="";
if(rowObject.effects){
str = ((rowObject.total_win_agent / rowObject.effects)*100).toFixed(2) + "%";
}else{
str = "-";
}
return str;
}
}
],
//在哪一列展开树形
treeShowField: 'id',//属性结构中三角的位置
//指定父id列
parentIdField: "parent",//根据这个字段来确定哪个是父元素
onResetView: function(data) {
//console.log('load');
$table.treegrid({
initialState: 'collapsed',// 所有节点都折叠
// initialState: 'expanded',// 所有节点都展开,默认展开
treeColumn: 0,//默认展开几层,0代表全部不展开
// expanderExpandedClass: 'glyphicon glyphicon-minus', //图标样式
// expanderCollapsedClass: 'glyphicon glyphicon-plus',
onChange: function() {
$table.bootstrapTable('resetWidth');
}
});
},

  到这里就可以正确的加载第一次的数据了。但是如果我们有自己的搜索条件,需要改变queryParams中的值就可以了,请看下面的代码:

  //点击搜索按钮
function search_bth(){
var user_number = $("#user_number").val();//商户号
var player_id = $("#player_id").val();//玩家账号
var record_id = $("#record_id").val();//游记录ID
var game_id = $("#game_id").val();//游戏局ID
var game_type = $("#game_type").val();//游戏类型
var creat_time = $("#start_time").val();//游戏时间
var filter_data = {}
//去掉空格校验
if($.trim(user_number)){
filter_data.agentId = $.trim(user_number);
}
if($.trim(player_id)){
filter_data.account = $.trim(player_id);
}
if($.trim(record_id)){
filter_data.orderId = $.trim(record_id);
}
if($.trim(game_id)){
filter_data.roundId = $.trim(game_id);
}
if($.trim(game_type)){
filter_data.gameId = $.trim(game_type);
}
if($.trim(creat_time)){
filter_data.creatTime = $.trim(creat_time);
} console.log(filter_data);
//debugger;
//$("#table_list_1").bootstrapTable('destroy');
// $('#table_list_1').bootstrapTable({
// queryParams:filter_data,
// url: "__ROOT__/public/js/data.json",
// });
$('#table_list_1').bootstrapTable('refresh',{query:filter_data})//等到我们需要传输的参数,直接刷新页面
}

  最重要的就是37行的代码,我们用query就可以重新发送请求,然后获取到最新的数据了!

bootstrap-table 常用总结-1的更多相关文章

  1. JS组件系列——表格组件神器:bootstrap table(三:终结篇,最后的干货福利)

    前言:前面介绍了两篇关于bootstrap table的基础用法,这章我们继续来看看它比较常用的一些功能,来个终结篇吧,毛爷爷告诉我们做事要有始有终~~bootstrap table这东西要想所有功能 ...

  2. 表格组件神器:bootstrap table详细使用指南

    1.bootstrap-table简介 1.1.bootstrap table简介及特征: Bootstrap table是国人开发的一款基于 Bootstrap 的 jQuery 表格插件,通过简单 ...

  3. ABP+AdminLTE+Bootstrap Table权限管理系统第五节--WBEAPI及SwaggerUI

    一,Web API ABP的动态WebApi实现了直接对服务层的调用(其实病没有跨过ApiController,只是将ApiController公共化,对于这一点的处理类似于MVC,对服务端的 调用没 ...

  4. ABP module-zero +AdminLTE+Bootstrap Table+jQuery权限管理系统第十二节--小结,Bootstrap Table之角色管理

    返回总目录:ABP+AdminLTE+Bootstrap Table权限管理系统一期 很多人说ABP不适合高并发大型,有一定的道理,但是我觉得还是可以的,就看架构师的能力了,哈哈,我之前公司就是ABP ...

  5. ABP module-zero +AdminLTE+Bootstrap Table+jQuery权限管理系统第十七节--Quartz与ABP框架Abp.Quartz及扩展

    ABP+AdminLTE+Bootstrap Table权限管理系统一期 Github:https://github.com/Jimmey-Jiang/ABP-ASP.NET-Boilerplate- ...

  6. bootstrap table使用参考

    https://www.cnblogs.com/landeanfen/p/5821192.html  转载 阅读目录 一.x-editable组件介绍 二.bootstrapTable行内编辑初始方案 ...

  7. ABP module-zero +AdminLTE+Bootstrap Table+jQuery权限管理系统第十五节--缓存小结与ABP框架项目中 Redis Cache的实现

    返回总目录:ABP+AdminLTE+Bootstrap Table权限管理系统一期 缓存 为什么要用缓存 为什么要用缓存呢,说缓存之前先说使用缓存的优点. 减少寄宿服务器的往返调用(round-tr ...

  8. [转]手把手教你--Bootstrap Table表格插件及数据导出(可导出Excel2003及Exce2007)

    原文地址:https://blog.csdn.net/javayoucome/article/details/80081771 1.介绍 Bootstrap Table介绍见官网:http://boo ...

  9. bootstrap table教程--使用入门基本用法

    笔者在查询bootstrap table资料的时候,看了很多文章,发觉很多文章都写了关于如何使用bootstrap table的例子,当然最好的例子还是官网.但是对于某部分技术人员来说,入门还是不够详 ...

  10. Bootstrap框架常用总结

    Bootstrap框架常用标签:    标题标签:<h1>-<h6>        bootstrap中也设置的相同的样式  - 若要使用 必须使用空标签来定义 比如<s ...

随机推荐

  1. 图形界面GUI

    JFrame jframe = new JFrame(); //创建一个窗口 jframe.setVisible(true) //设置窗口显示 jframe.setLocation() //设置窗口位 ...

  2. 地兵布阵 -----------HDU-1166

    C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况.由于 ...

  3. POJ 2559 Langest Rectangle in a Histogame

    A histogram is a polygon composed of a sequence of rectangles aligned at a common base line. The rec ...

  4. Kinect-v2 Examples with MS-SDK(译文二)

    K2-asset提供的脚本组件 K2-asset在KinectScripts文件夹中提供通用脚本组件,并在KinectDemos / 文件夹的相应脚本子文件夹中提供特定于演示的组件.可以在自己的Uni ...

  5. 上手spring boot项目(三)之spring boot整合mybatis进行增删改查

    使用mybatis框架进行增删改查大致有两种基础方式,一种扩展方式.两种基础方式分别是使用xml映射文件和使用方法注解.扩展方式是使用mybatis-plus的方式,其用法类似于spring-data ...

  6. 【Maven】常用命令

    [Maven]常用命令 转载:https://www.cnblogs.com/yangchongxing/p/10267028.html Maven Jar 搜索:https://mvnreposit ...

  7. 【JPA】注解@PostConstruct、@PreDestroy

    从Java EE5规范开始,Servlet增加了两个影响Servlet生命周期的注解@PostConstruct和@PreConstruct.这两个注解被用来修饰一个非静态的void()方法,而且这个 ...

  8. 计算机二级Python

    概述 计算机二级在近两年新加了python的选择,趁机考了一下,顺便记录一下学习的一些所获 第一章 程序设计语言概述 考纲考点: 这一部分主要是介绍计算机语言的公共常识,一些尝试我就按照自己的理解方式 ...

  9. eps-07s,编译及其烧写

    项目导入 清理并编译 会出现两个bin文件,然后烧写 修改红框中的东西,然后返回操作界面,进行一键烧写 硬件接线图 设备调试

  10. uploadify没反应

    由于业务问题,需要用到uploadify这个插件,结果官方的case怎么弄都没问题,弄到自己的页面上就有问题了. 后来发现,这个插件是要用到swf的,但是页面加载的过程中并没有加载swf文件,所以将问 ...