bootstrap table php,bootstrap Table从零开始

ac6856be70e4d3a7ca2d632e2dd5a4d0.png

本文小编将带大家从零开始,一步一步的告诉大家如何在前端用bootstrap Table插件展示一个表格

本文需要注意点地方小编已用红笔圈起来

先展示效果图

c0f8d0432591b1bb7536a71aabfb28ce.png

接下来就开始使用bootstrap Table插件制作表格

将上述地址下载的插件js放到项目中,分别为js,css,fonts

ae8bcdf719226c89f152d04d059a038d.png

此处有一个细节:locale文件夹的名字不能修改,而且里边的所有语言js,必须全部粘过来,本文以MVC为例,当然WebForm也是可以的

使用步骤:

1、新建一个控制器和视图,该视图引用了_Layout母页版

2、在视图里引用相应的js

2f4b4e751000fd5a66b9bb59b508ce77.png

在页面上写一个table表格容器,这一句必须要有

3、初始化bootstrap Table$(function () {

//1.初始化Table

var oTable = new TableInit();

oTable.Init();

});

4、使用bootstrap Tablevar TableInit = function () {

var oTableInit = new Object();

//初始化Table

oTableInit.Init = function () {

$('#ArbetTable').bootstrapTable({

url: '/Interface/GetData', //请求后台的URL(*)

method: 'get', //请求方式(*)

toolbar: '#toolbar', //工具按钮用哪个容器

striped: true, //是否显示行间隔色

cache: false, //是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)

pagination: true, //是否显示分页(*)

sortable: false, //是否启用排序

sortOrder: "asc", //排序方式

queryParams: oTableInit.queryParams,//传递参数(*)

sidePagination: "server", //分页方式:client客户端分页,server服务端分页(*)

pageNumber: 1, //初始化加载第一页,默认第一页

pageSize: 10, //每页的记录行数(*)

pageList: [10, 25, 50, 100], //可供选择的每页的行数(*)

search: true, //是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大

contentType: "application/x-www-form-urlencoded",

strictSearch: true,

showColumns: true, //是否显示所有的列

showRefresh: true, //是否显示刷新按钮

minimumCountColumns: 2, //最少允许的列数

clickToSelect: true, //是否启用点击选中行

height: 700, //行高,如果没有设置height属性,表格自动根据记录条数觉得表格高度

uniqueId: "no", //每一行的唯一标识,一般为主键列

showToggle: true, //是否显示详细视图和列表视图的切换按钮

cardView: false, //是否显示详细视图

detailView: false, //是否显示父子表

columns: [

{

field: 'ID',

title: 'ID'

}, {

field: 'Name',

title: '名字'

}, {

field: 'Sex',

title: '性别'

},

{

field: 'operate',

title: '操作',

formatter: operateFormatter //自定义方法,添加操作按钮

},

],

rowStyle: function (row, index) {

var classesArr = ['success', 'info'];

var strclass = "";

if (index % 2 === 0) {//偶数行

strclass = classesArr[0];

} else {//奇数行

strclass = classesArr[1];

}

return { classes: strclass };

},//隔行变色

});

};

//得到查询的参数

oTableInit.queryParams = function (params) {

var temp = { //这里的键的名字和控制器的变量名必须一直,这边改动,控制器也需要改成一样的

limit: params.limit, //页面大小

offset:params.offset

};

return temp;

};

return oTableInit;

};

function operateFormatter(value, row, index) {//赋予的参数

return [

'编辑',

'档案',

'记录',

'准入'

].join('');

}

4、后台url返回数据public ActionResult GetData(int limit, int offset)

{

var data = new List(){new { ID=1, Name="Arbet", Sex="男"},

new { ID= 2, Name="Arbet1", Sex="女" },

new {ID=3, Name="Arbet2",Sex="男" },

new {ID=4, Name="Arbet3",Sex="女" },

new {ID=5, Name="Arbet4",Sex="男" },

new {ID=6, Name="Arbet5",Sex="男" },

new {ID=7, Name="Arbet6",Sex="女" },

new {ID=8, Name="Arbet7",Sex="男" },

new { ID=9, Name="Arbet1", Sex="女" },

new {ID=10, Name="Arbet2",Sex="男" },

new {ID=11, Name="Arbet3",Sex="女" },

new {ID=12, Name="Arbet4",Sex="男" },

new {ID=13, Name="Arbet5",Sex="男" },

new {ID=14, Name="Arbet6",Sex="女" },

new {ID=15, Name="Arbet7",Sex="男" }

};

var total = data.Count;

var rows = data.Skip(offset).Take(limit).ToList();

return Json(new { total = total, rows = rows }, JsonRequestBehavior.AllowGet);

}

在本文中,博主以匿名集合来设置数据,大家可以通过查询数据库获取数据

在此需要注意:返回的参数必须是total和rows,total返回数据集总个数,rows返回table的json格式

5、展示效果

212d9299faa8571069559865740e768e.png

发现出现了这个bug,这是怎么回事

在浏览器上打开源代码

78a03322f7a16ba085992db7d287b6be.png

发现多了一些其他js文件,这是layout母页版里引入的js文件

@ViewBag.Title

@Styles.Render("~/Content/css")

@Scripts.Render("~/bundles/modernizr")

@RenderBody()

@*@Scripts.Render("~/bundles/jquery")*@

@RenderSection("scripts", required: false)

把上图中的红框里的js文件注释掉再运行

bc7ae00aa78f64fffbb5d54928aeed4a.png发现成功了!这是因为JS库文件的引用是有顺序的,必须先引用JQuery库文件,再引用插件js

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值