欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Bootstrap Table从零开始

程序员文章站 2022-06-09 08:51:05
本文博主将从零开始,一步一步的告诉大家如何在前端用bootstrap table插件展示一个表格 首先,要下载bootstrap table插件所必须的js,地址: 官...

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

首先,要下载bootstrap table插件所必须的js,地址:

官方文档地址:

本文项目地址:bootstraptable

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

先展示效果图

Bootstrap Table从零开始

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

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

Bootstrap Table从零开始

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

本文以mvc为例,当然webform也是可以的

使用步骤:

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

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

Bootstrap Table从零开始

在页面上写一个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、展示效果

Bootstrap Table从零开始

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

在浏览器上打开源代码

Bootstrap Table从零开始

发现多了一些其他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文件注释掉再运行

Bootstrap Table从零开始

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。