博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bootstrap-table填坑之旅<一>认识bootstrap-table
阅读量:6373 次
发布时间:2019-06-23

本文共 8943 字,大约阅读时间需要 29 分钟。

应公司需求,改版公司ERP的数据显示样式。由于前期开发的样式是bootstrap,所以选bootstrap-table理所当然(也是因为看了bootstrap-table官网的example功能强大,样式清爽)。

然后... ... 开启bootstrap-table填坑之旅。

开始就扒本园的资源,确实有不少bootstrap-table的文章。确实写的不错很详细,请恕本菜实在菜了点,看了半天demo的页面都没弄出来(勿吐槽~~)。终于11点了.. .. 于是决定跟着官网的小白教程一点点的玩。

ready... .. 

1. 怎么把table挂出来

HTML代码:(只用看一个tr就够了,写三行只为看demo效果)

序号 商品名称 开始时间 结束时间
1 九洲奇味饼干 2016/10/9 10:15:00 2016/12/25 11:30:00
2 好多鱼 2016/10/9 10:15:00 2016/12/25 11:30:00
3 旺旺雪饼 2016/10/9 10:15:00 2016/12/25 11:30:00

终于把table挂出来了,这里其实就和原来的table一样写就行了。

2. 加载json数据

HTML代码:

序号 商品名称 开始时间 结束时间

js代码:

/*数据json*/        var json =  [{"Code":"1","TuanGouName":"好多鱼","StartDate":"2016/10/9 10:15:00","EndTime":"2016/12/25 11:30:00"},                        {
"Code":"2","TuanGouName":"旺旺雪饼","StartDate":"2016/10/9 10:15:00","EndTime":"2016/12/25 11:30:00"}, {
"Code":"3","TuanGouName":"旺旺仙贝","StartDate":"2016/10/9 10:15:00","EndTime":"2016/12/25 11:30:00"}, {
"Code":"4","TuanGouName":"雪花清爽","StartDate":"2016/10/9 10:15:00","EndTime":"2016/12/25 11:30:00"}, {
"Code":"5","TuanGouName":"勇闯天涯","StartDate":"2016/10/9 10:15:00","EndTime":"2016/12/25 11:30:00"}, {
"Code":"6","TuanGouName":"九洲奇味饼干","StartDate":"2016/10/9 10:15:00","EndTime":"2016/12/25 11:30:00"}]; /*初始化table数据*/ $(function(){ $("#goods").bootstrapTable({ data:json }); });

成功获取json数据并加载成功。

这里注意:用json加载数据 table 标签不能写 data-toggle="table" 属性,至于原因......总之这里不能写,写了就会出这样的bug。

3. 装饰table

HTML代码

Name Stars Forks Description

js代码

function rowStyle(value, index) {    var classes = ['active', 'success', 'info', 'warning', 'danger'];    if (index % 2 === 0) {        return { classes: 'success' };    }    return {};}

data-striped属性true表格为隔行变色(斑马纹),false不使用隔行变色。

data-row-style属性接收js函数(必须有返回值),可设置row属性。

th每列可添加栅格样式。

在th可设置data-cell-style属性,同样接收js函数(必须有返回值),设置该列单元格样式。

HTML代码

Name Stars Forks

data-halign设置该列标题对齐,data-align设置该列单元格对齐。

分组列显示——colspan & rowspan

js

/*列信息*/        var firstCol = [                        [{
"field":"goodsName","title":"商品名称","colspan":1,"rowspan":2}, {
"title":"商品信息","colspan":2,"rowspan":1}], [{
"field":"goodsInfo.price","title":"价格","colspan":1,"rowspan":1}, {
"field":"goodsInfo.date","title":"日期","colspan":1,"rowspan":1}] ]; /*数据*/ var data = [{"goodsName":"旺旺仙贝","goodsInfo":{"price":"$26","date":"2018-08-10"}}, {
"goodsName":"乐事薯片","goodsInfo":{"price":"$18","date":"2020-10-25"}}, {
"goodsName":"勇闯天涯","goodsInfo":{"price":"$20","date":"2017-01-10"}}]; /*初始化表格*/ $(function(){ $("#goods").bootstrapTable({ columns: firstCol, data: data }); });

分组列组名不需要申明field值,但分组列子列的field值需要带上列组名(格式:Group.GroupChild)。如果分组列,数据的json也需要做相应的调整。

4. table排序

HTML代码

序号 商品名称 开始时间 结束时间

data-sortable属性默认为false,设置为true,按默认排序方式对该列内容排序。

data-sort-order排序方向,asc升序排列、desc降序排列。

data-sort-name="stargazers_count"这俩属性找了半天没找到准确的解释,从字面意思理解应该是默认的排序函数名和排序方式,总之带上总没错。

5. 单元格 格式化

HTML代码

下标 序号 商品名称 名称 结束时间

js代码

function getIndex(val,row,index){            return index + 1;        }        function setCode(val){            return "" + val + "";        }        function setName(val){            return "" + val + "";        }

data-formatter属性可以格式化该列单元格,data-formatter接收js函数(必须有返回值)该函数可以获取当前行的下标(注意:获取下标参数必须有row,否则index值为undefined),函数还可以改变单元格元素显示方式,例如:a button .. ...

6. 显示隐藏列

HTML代码

序号 商品名称 名称 结束时间

data-show-columns属性为“true”可设置隐藏显示某列,对应列data-switchable属性设置为“false”该列不可隐藏,默认值为true;data-visible属性设置为“false”该列默认被隐藏,默认值为true。

7. 选择列 checkbox

HTML代码

序号 商品名称 名称 结束时间

<th data-field="state" data-checkbox="true"></th>这一列是checkbox选择列。据测试,data-click-to-select属性的值与选择列关系不大,有木有或者值true false都不影响checkbox列的显示和使用。

设置data-single-select="true",checkbox就只能选择一行。

选择 序号 商品名称 名称 结束时间

通过js指定行被选中,指定行不可操作。

function stateFormatter(value, row, index) {    if (index === 2) {        return {            disabled: true        };    }    if (index === 0) {        return {            disabled: true,            checked: true        }    }    return value;}

给checkbox设置data-formatter属性,通过disabledchecked控制checkbox是否可用和是否被选中。

获取选中行信息

html

js

/*获取选中行对象*/        function getContent(){            var index = $("#table").find("tr.danger").data("index");            return $("#table").bootstrapTable('getData')[index];        }        /*初始化table数据*/        $(function(){            $("#table").bootstrapTable('destroy').bootstrapTable({                columns:columns,                data:json            });            $("#table").on("click-row.bs.table",function(e,row,ele){                $(".danger").removeClass("danger");                $(ele).addClass("danger");            });            $("#get").click(function(){                alert("商品名称:" + getContent().TuanGouName);            })        });

给table绑定click-row.bs.table函数(行点击事件),callback(回调)函数列表:e(Event:事件对象),row(Rows:table行),ele(Element:选中行对象)。给选中行添加颜色样式,移除上一个被选行样式。

getContent()函数分析:

var index 获取被选中行下表,find搜索被选中行(即带样式的行),data被选中行在数据集中的下标。

return 返回table中被选中行对象。

点击查询按钮click事件:

既然getContent()已获取被选中行对象,需要获取哪个单元格,就调哪个单元格的field值。

8. card-view 卡片视图

HTML代码

Name Stars Forks Description

data-card-view改变table视图方式,true:卡片视图,false:表格视图。

9. toolbar工具栏(常用 搜索 刷新 切换试图 筛选列)

HTML代码

序号 商品名称 名称 结束时间

data-search:搜索(自动搜索,输入后自动搜索)

data-show-refresh:刷新

data-show-toggle:切换试图(卡片试图 and 表格试图)

data-show-columns:筛选列

自定义添加工具栏按钮

Name Stars Forks Description

data-toolbar添加自定义工具栏(value建议为ID值)。

10.分页pagination

HTML代码

js代码

function queryParams() {            return {                type: 'owner',                            sort: 'updated',                     direction: 'desc',            //排序方向                per_page: 10,                //一次加载数据条数                page:1                        //加载数据第几次            };        }

data-page-list定义每页显示条数,接受数组。例:data-page-list="[2,4,6,10,20]"

data-pagination值为true,表格使用分页,data-query-params分页配置参数,接受js函数(必须有返回值)。

direction排序方向:asc升序,desc降序

per_page一次性加载数据条数:int整数

page请求数据次数

例:如共有190条数据,page值为1,per_page值为100。table加载第1~100条数据,

page值为2,per_page值为100。table加载第201~300条数据。

注意:data-query-params仅对请求数据地址有对应参数的返回值才生效,对json拉取到本页解析的数据和本页直接生成的数据皆无效。不懂的自己多调试几遍,这里我调了半个小时

关于服务器端分页请参考这个

更多详细还是看官方文档:

转载于:https://www.cnblogs.com/MirageFox/p/5981867.html

你可能感兴趣的文章
面对对象之差异化的网络数据交互方式--单机游戏开发之无缝切换到C/S模式
查看>>
优酷网架构学习笔记
查看>>
把HDFS里的json数据转换成csv格式
查看>>
WEEX-EROS | 集成并使用 bindingx
查看>>
广州牵引力来告诉你学编程先学什么语言好?
查看>>
广州牵引力总结初学者怎样学好UI设计?
查看>>
使用Metrics方法级远程监控Java程序
查看>>
Spring核心系列之Bean的生命周期
查看>>
VasSonic源码之并行加载
查看>>
小程序 LRU 存储设计
查看>>
Android 多线程之阻塞队列
查看>>
Haskell 在 macOS 下的环境搭建
查看>>
适配mpvue平台的的微信小程序日历组件mpvue-calendar
查看>>
【Linux学习】 Redis常用的一些指令
查看>>
Spring Cloud 中使用Feign解决参数注解无法继承的问题
查看>>
数据迁移方案 + Elasticsearch在综合搜索列表实现
查看>>
干货 | 分分钟教你用Python创建一个区块链
查看>>
Angular开发实践(八): 使用ng-content进行组件内容投射
查看>>
canvas+websocket+vue做一个完整的你画我猜小游戏
查看>>
android复习清单
查看>>