当前位置: 首页 >前端技术 > bootstrap Table从零开始

bootstrap Table从零开始

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

首先,要下载bootstrap Table插件所必须的js,地址:https://github.com/wenzhixin/bootstrap-table

官方文档地址:http://bootstrap-table.wenzhixin.net.cn/zh-cn/documentation/

 本文项目地址:https://pan.baidu.com/s/1sk9w6D3


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

先展示效果图

bootstrap Table从零开始 _ JavaClub全栈架构师技术笔记

 

 


 

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

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

bootstrap Table从零开始 _ JavaClub全栈架构师技术笔记

此处有一个细节:locale文件夹的名字不能修改,而且里边的所有语言js,必须全部粘过来

本文以MVC为例,当然WebForm也是可以的

使用步骤:

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

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

bootstrap Table从零开始 _ JavaClub全栈架构师技术笔记

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

<table id="ArbetTable"></table>

3、初始化bootstrap Table

1 $(function () {2 //1.初始化Table3 var oTable = new TableInit();4 oTable.Init();5 });

4、使用bootstrap Table

 1 var TableInit = function () { 2 var oTableInit = new Object(); 3 //初始化Table 4 oTableInit.Init = function () { 5 $('#ArbetTable').bootstrapTable({ 6 url: '/Interface/GetData', //请求后台的URL(*) 7 method: 'get',  //请求方式(*) 8 toolbar: '#toolbar',//工具按钮用哪个容器 9 striped: true,  //是否显示行间隔色10 cache: false,//是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)11 pagination: true,//是否显示分页(*)12 sortable: false, //是否启用排序13 sortOrder: "asc",//排序方式14 queryParams: oTableInit.queryParams,//传递参数(*)15 sidePagination: "server",//分页方式:client客户端分页,server服务端分页(*)16 pageNumber: 1,//初始化加载第一页,默认第一页17 pageSize: 10,//每页的记录行数(*)18 pageList: [10, 25, 50, 100],//可供选择的每页的行数(*)19 search: true,//是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大20 contentType: "application/x-www-form-urlencoded",21 strictSearch: true,22 showColumns: true,  //是否显示所有的列23 showRefresh: true,  //是否显示刷新按钮24 minimumCountColumns: 2, //最少允许的列数25 clickToSelect: true,//是否启用点击选中行26 height: 700,//行高,如果没有设置height属性,表格自动根据记录条数觉得表格高度27 uniqueId: "no", //每一行的唯一标识,一般为主键列28 showToggle: true,//是否显示详细视图和列表视图的切换按钮29 cardView: false,//是否显示详细视图30 detailView: false,//是否显示父子表31 columns: [32 {33 field: 'ID',34 title: 'ID'35 }, {36 field: 'Name',37 title: '名字'38 }, {39 field: 'Sex',40 title: '性别'41 },42 {43 field: 'operate',44 title: '操作',45 formatter: operateFormatter //自定义方法,添加操作按钮46 },47 ],48 rowStyle: function (row, index) {49 var classesArr = ['success', 'info'];50 var strclass = "";51 if (index % 2 === 0) {//偶数行52 strclass = classesArr[0];53 } else {//奇数行54 strclass = classesArr[1];55 }56 retu { classes: strclass };57 },//隔行变色58 });59 60 };61 62 63 //得到查询的参数64 oTableInit.queryParams = function (params) {65 var temp = {//这里的键的名字和控制器的变量名必须一直,这边改动,控制器也需要改成一样的66 limit: params.limit,//页面大小67 offset:params.offset68 };69 retu temp;70 };71 retu oTableInit;72 };73 74 75 function operateFormatter(value, row, index) {//赋予的参数76 retu [77 '<a class="btn active disabled" href="#">编辑</a>',78 '<a class="btn active" href="#">档案</a>',79 '<a class="btn btn-default" href="#">记录</a>',80 '<a class="btn active" href="#">准入</a>'81 ].join('');82 }

4、后台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();retu Json(new { total = total, rows = rows }, JsonRequestBehavior.AllowGet);}

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

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

 

5、展示效果

bootstrap Table从零开始 _ JavaClub全栈架构师技术笔记

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

在浏览器上打开源代码

bootstrap Table从零开始 _ JavaClub全栈架构师技术笔记

发现多了一些其他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/modeizr")</head><body>@RenderBody()@*@Scripts.Render("~/bundles/jquery")*@@RenderSection("scripts", required: false)</body></html>

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

bootstrap Table从零开始 _ JavaClub全栈架构师技术笔记

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

 

作者:Arbet
来源链接:https://www.cnblogs.com/baixiaoguang/p/7094459.html

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/front/117447.html

标签:Bootstrap
分享给朋友:

“bootstrap Table从零开始” 的相关文章

一文带你了解React框架 2022年05月16日 21:17:44
JavaScript提高班之ES6(七) 2022年05月16日 21:21:41
a标签有哪些属性 2022年05月17日 21:02:23
HTML5 自动聚焦autofocus属性 2022年06月06日 04:30:20
HTML标签及其属性 2022年06月06日 17:08:10
HTML中script标签 2022年06月10日 21:53:33
html a标签链接 点击下载文件 2022年06月14日 20:37:20
JS 选择性修改input标签的属性 2022年06月15日 23:49:35