Bootstrap Table从零开始
程序员文章站
2022-06-09 08:51:05
本文博主将从零开始,一步一步的告诉大家如何在前端用bootstrap table插件展示一个表格
首先,要下载bootstrap table插件所必须的js,地址:
官...
本文博主将从零开始,一步一步的告诉大家如何在前端用bootstrap table插件展示一个表格
首先,要下载bootstrap table插件所必须的js,地址:
官方文档地址:
本文项目地址:bootstraptable
本文需要注意点地方博主已用红笔圈起来
先展示效果图
接下来就开始使用bootstrap table插件制作表格
将上述地址下载的插件js放到项目中,分别为js,css,fonts
此处有一个细节:locale文件夹的名字不能修改,而且里边的所有语言js,必须全部粘过来
本文以mvc为例,当然webform也是可以的
使用步骤:
1、新建一个控制器和视图,该视图引用了_layout母页版
2、在视图里引用相应的js
在页面上写一个table表格容器,这一句必须要有
<table id="arbettable"></table>
3、初始化bootstrap table
$(function () { //1.初始化table var otable = new tableinit(); otable.init(); });
4、使用bootstrap table
var 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 [ '<a class="btn active disabled" href="#">编辑</a>', '<a class="btn active" href="#">档案</a>', '<a class="btn btn-default" href="#">记录</a>', '<a class="btn active" href="#">准入</a>' ].join(''); }
5、后台url返回数据
public actionresult getdata(int limit, int offset) { var data = new list<object>(){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格式
6、展示效果
发现出现了这个bug,这是怎么回事
在浏览器上打开源代码
发现多了一些其他js文件,这是layout母页版里引入的js文件
<!doctype html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width" /> <title>@viewbag.title</title> @styles.render("~/content/css") @scripts.render("~/bundles/modernizr") </head> <body> @renderbody() @*@scripts.render("~/bundles/jquery")*@ @rendersection("scripts", required: false) </body> </html>
把上图中的红框里的js文件注释掉再运行
发现成功了!这是因为js库文件的引用是有顺序的,必须先引用jquery库文件,再引用插件js
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。