为了账号安全,请及时绑定邮箱和手机立即绑定

前端框架:Bootstrap table 分页,排序,搜索 记录

做CRM或其他后台系统 ,必需至少掌握一个前端框架。
之前学习使用EASYUI写了一个小系统 ,感觉还蛮好用的,就是外观不太好看。
所以现在学习主流的响应式框架 Bootstrap。感觉外观还真是变好看的~哈

1.引用JS 使用的是 bootstrap-3.3.5-dist
2.引用table插件 bootstrap-table.js(谷歌搜索下就有~)
3.引用paginator插件 bootstrap-paginator.js(谷歌搜索下就有~)

前端代码如下:


<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>TableTest2</title>
    <link href="~/Content/bootstrap-3.3.5-dist/css/bootstrap.min.css" rel="stylesheet" />
    <link href="~/Content/bootstrap-table/bootstrap-table.css" rel="stylesheet" />
    <script class="lazyload" src="" data-original="~/Scripts/jquery-1.8.2.min.js"></script>
    <script class="lazyload" src="" data-original="~/Content/bootstrap-3.3.5-dist/js/bootstrap.min.js"></script>
    <script class="lazyload" src="" data-original="~/Content/bootstrap-table/bootstrap-table.js"></script>
    <script class="lazyload" src="" data-original="~/Content/bootstrap-table/bootstrap-paginator.js"></script>
    <script class="lazyload" src="" data-original="~/Content/bootstrap-table/bootstrap-table-zh-CN.js"></script>
</head>
<body>

    <table id="test-table" class="col-xs-12" data-toolbar="#toolbar"></table>

    <script type="text/javascript">

        $(document).ready(function () {

            initTable();

        })

        function initTable() {
            $('#test-table').bootstrapTable({
                method: 'post',
                toolbar: '#toolbar',    //工具按钮用哪个容器
                striped: true,      //是否显示行间隔色
                cache: false,      //是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)
                pagination: true,     //是否显示分页(*)
                sortable: true,      //是否启用排序
                sortOrder: "ID asc",     //排序方式
                pageNumber: 1,      //初始化加载第一页,默认第一页
                pageSize: 12,      //每页的记录行数(*)
                pageList: [20, 50, 100, 150],  //可供选择的每页的行数(*)
                url: "/home/tablePost3",//这个接口需要处理bootstrap table传递的固定参数
                queryParamsType: '', //默认值为 'limit' ,在默认情况下 传给服务端的参数为:offset,limit,sort
                // 设置为 '' 在这种情况下传给服务器的参数为:pageSize,pageNumber

                //queryParams: queryParams,//前端调用服务时,会默认传递上边提到的参数,如果需要添加自定义参数,可以自定义一个函数返回请求参数
                sidePagination: "server",   //分页方式:client客户端分页,server服务端分页(*)
                //search: true, //是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大
                strictSearch: true,
                //showColumns: true, //是否显示所有的列
                //showRefresh: true, //是否显示刷新按钮
                minimumCountColumns: 2,    //最少允许的列数
                clickToSelect: true,    //是否启用点击选中行
                searchOnEnterKey: true,
                search:true,
                columns: [
                 {
                    title: "ID",
                    field: "ID",
                    align: "center",
                    valign: "middle",
                    formatter: function (value, row, index) {
                        //通过formatter可以自定义列显示的内容
                        //value:当前field的值,即id
                        //row:当前行的数据
                        var a = '<a href="/home/edit?id='+value+'" >修改</a>';
                        return a;
                    }
                },
                {
                    title: "Sku",
                    field: "Sku",
                    align: "center",
                    valign: "middle",
                    sortable:true

                },
                {
                    title: "ProductName",
                    field: "ProductName",
                    align: "center",
                    valign: "middle"
                },
                {
                    title: "Price",
                    field: "Price",
                    align: "center",
                    valign: "middle"
                },
                    {
                        title: "Descrtiption",
                        field: "Descrtiption",
                        align: "center",
                        valign: "middle"
                    }

                ],
                pagination: true
            });
        }

    </script>

</body>
</html>

后端请求代码:


        [HttpPost]
        public JsonResult tablePost3(string searchText="",string sortName ="",string sortOrder="desc",int pageSize = 10, int pageNumber = 1)
        {

            //1.排序
            //2.字段排序 
            //3.搜索关键字

            var db = new QHC_IIMSContext();
            List<Models.Models.T_Product> proList = null;
            if (sortOrder == "desc")
            {
                //desc 降序
                proList = db.T_Product.OrderByDescending(t => t.ID).Skip((pageNumber - 1) * pageSize).Take(pageSize).ToList();
            }
            else
            {
                //asc 升序
                proList = db.T_Product.OrderBy(t => t.ID).Skip((pageNumber - 1) * pageSize).Take(pageSize).ToList();
            }

            //获取数据库总条数
            int total = db.T_Product.Count();

            //匿名list  可以筛
            var newList = proList.Select(t => new { ID = t.ID, Sku = t.Sku, ProductName = t.ProductName, Price = t.Price, Descrtiption = t.Descrtiption }).ToList();

            var json = new { total = total, rows = newList };

            return Json(json, JsonRequestBehavior.AllowGet);
        }

前端显示 时,注意JSON中的数据的大小写问题

点击排序SKU,提交请求
图片描述

返回结果:
图片描述

点击查看更多内容
58人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消