zoukankan      html  css  js  c++  java
  • DataTable表头对不齐、添加参数等方法总结

    tableData:

    一:写这篇博客是因为我在网上找到了改变行颜色,没有找到改变td颜色的改变文章,也许好多朋友早就找到了或感觉这个太简单,但不管怎样我还是写下了这篇没有技术含量的一篇。

    前提:引入依赖文件

    <link href="__PUBLIC__/html/css/plugins/dataTables/dataTables.bootstrap.css" rel="stylesheet">
    
    
    <script src="__PUBLIC__/html/js/plugins/dataTables/jquery.dataTables.js"></script>
    <script src="__PUBLIC__/html/js/plugins/dataTables/dataTables.bootstrap.js"></script>
    

      

    1.html内容:

      1).第一种:title写到html中

      2)第二种:title动态写入

      

        绑定数据时:

      

     2.js 绑定字段

       tips:这两部分是我们页面中使用改动比较多的部分。

    3.给每一行或指定的字段设置颜色等等

    这段代码很简单,当然代码中的13要根据自己想要的效果去设置,但缺点是加载可能会延迟。

    二、附上整体的代码

    <table id="staff" class="table table-bordered table-hover table-striped">
           <thead>
                <tr>
                    <th>合同编号</th>
                     <th>供方名称</th>
                      <th>供方地址</th>
                      <th>签订时间</th>
                      <th>签订地点</th>
                       <th>总金额</th>
                       <th>收货人</th>
                       <th>交货地点</th>
                       <th>收货电话</th>
                       <th>结算方式</th>
                       <th>供方法定代表</th>
                       <th>供方代表电话</th>
                       <th>供方代表传真</th>
                       <th>是否回传合同附件</th>
                       <th>订单状态</th>
                       <th>审核状态</th>
                     </tr>
                 </thead>
              <tbody>
           </tbody>
    </table>
    
    
     var table = $('#staff'). DataTable({
            ajax: {
                type: 'post',
                data: {
                    flag: 1
                },
            },
            "scrollY": 440,
            "scrollX": false,
            "scrollCollapse": true,
            "destroy"      : true,
            "paging"       : true,
            "autoWidth"	   : false,
            "pageLength": 25,
            serverSide: true,
            // order:[[21, 'desc']],
            columns: [
                {searchable: true, data: 'contract_id'},
                {searchable: true, data: 'supplier_name'},
                {searchable: true, data: 'supply_address'},
                {searchable: true, data: 'signing_time'},
                {searchable: true, data: 'signing_place'},
                {searchable: false, data: 'total_amount'},
                {searchable: false, data: 'receiver'},
                {searchable: false, data: 'trading_location'},
                {searchable: true, data: 'receiving_phone'},
                {searchable: true, data: 'billing_method'},
                {searchable: true, data: 'supplier_representative'},
                {searchable: true, data: 'supplier_phone'},
                {searchable: true, data: 'supplier_fax'},
                {searchable: true, class:'suc' , data: 'is_return_contract', render: function (data){return ['否', '是'][+data]}},
                {searchable: true, data: 'order_status', render: function (data){return ['未生成订单','已生成订单','已生成订单','已生成订单','已生成订单'][+data]}},
                {searchable: true, data: 'audit_status', render: function (data){return ['新提交', '不合格','审核通过'][+data]}}
            ],
            'fnRowCallback':function(nRow,aData,iDisplayIndex,iDisplayIndexFull){
                /*
                    nRow:每一行的信息 tr  是Object
                    aData:行 index
                */
                for(let key in nRow){
                    var ADataStatus = nRow['childNodes'][13].innerText
                    if(ADataStatus == '否'){
                        $(nRow['childNodes'][13]).css("color",'red')
                    }else if(ADataStatus == '是'){
                        $(nRow['childNodes'][13]).css("color",'green')
                        
                    }
                }
    
            },
         //或者是 (变色)
      "columnDefs" : [ //自定义列
      {
      "targets" : 7,
      "data" : "stock_out_status",
      render : function(data, type, row) {
      data = parseInt(data);
      // var arr = ['未处理', '出库中', '出库完毕','未对接订单,无需处理'];
        var html = "";
      switch (data) {
      case 0 :
        html = "<span style='color:red'>";
          break;
      case 1 :
        html = "<span style='color:blue'>";
          break;
      case 2 :
        html = "<span style='color:green'>";
          break;
        default:
          html = "<span>";
        }
          html += stockOutMap[data] + "</span>";
        return html;
        }
      },
            oLanguage: {
                "oAria": {
                    "sSortAscending": " - click/return to sort ascending",
                    "sSortDescending": " - click/return to sort descending"
                },
                "LengthMenu": "显示 _MENU_ 记录",
                "ZeroRecords": "对不起,查询不到任何相关数据",
                "EmptyTable": "未有相关数据",
                "LoadingRecords": "正在加载数据-请等待...",
                "Info": "当前显示 _START_ 到 _END_ 条,共 _TOTAL_ 条记录。",
                "InfoEmpty": "当前显示0到0条,共0条记录",
                "InfoFiltered": "(数据库中共为 _MAX_ 条记录)",
                "Processing": "<img src='../resources/user_share/row_details/select2-spinner.gif'/> 正在加载数据...",
                "Search": "搜索:",
                "Url": "",
                "Paginate": {
                    "sFirst": "首页",
                    "sPrevious": " 上一页 ",
                    "sNext": " 下一页 ",
                    "sLast": " 尾页 "
                }
            }
        })
    

    三、效果截屏

      Datatable小总结

        1>只刷新当前页表格:table.draw(false) ;

        2>只刷表格:table.ajax.reload();

        3>table请求路径和参数:

        4>tablen内部分字段的映射另一种方法:

        5>点击获取datatable当前行的数据:

        6>关闭当前layer.open()页面:

     // layer.open页面关闭
    var index=parent.layer.getFrameIndex(window.name);//获取窗口索引
    parent.layer.close(index)

        7>.实现layer.tips和达到一定字数出现...

    {searchable: true, data: 'apply_reason',render:function (value,a, row) {
                    if (value){
                        value =  value.replace(/
    |
    /g, '<br>')
                        var allData = table.data();
                        var index = allData.indexOf(row);
                        var className = 'complain_reason' + index;
                        var str = ''
                        if (value.length > 10){
                            str = value.slice(0, 10) + '...'
                        } else {
                            str = value
                        }
                        return "<span class='complain_reason' id='" + className + "'>" + str + "</span>"
                    }
                    return value
                }},
    
    // layer tips
        $('#staff').on('mouseenter', 'td', function () {
            var that = $(this).children('span');
            if (that.hasClass('complain_reason') || that.hasClass('research') || that.hasClass('processes') || that.hasClass('processes_validity') || that.hasClass('liable')) {
                var data = table.cell(that.parents('td')).data()
                layer.tips(data, $(this), {time: 9999999})
            }
    
        })
        $('#staff').on('mouseleave', 'th', function () {
            layer.closeAll();
        })

         8> 添加额外的参数

    fnServerParams: function (aoData) {
           aoData['source_kind'] = select.value
    },
    
    //其中aoData是请求体,不变。fnServerParams是专门添加额外参数用的,这个函数和columns平级放置,至于放在哪儿无所谓。

         9> 表头对不齐

      表头莫名的错开了

      

      解决办法:

    #productionPlan{
           100% !important;
    }

      解决后的结果:

      

       官网地址:http://www.datatables.club/

  • 相关阅读:
    创建和发送事件
    (实战)为系统类添加NameValueTable属性,并且添加到相关对话框
    使用GetUniqueIndentifier为某类对象连续编码
    中秋小感
    数据库中取随机数的方法讨论
    CVS添加用户的过程和命令列表
    Mysql中获取刚插入的自增长id的三种方法归纳
    关于Action重复执行两遍的原因
    td内容空的时候,如何显示边框线
    2003下 tomcat 连mysql问题的解决
  • 原文地址:https://www.cnblogs.com/zeng2210/p/9531910.html
Copyright © 2011-2022 走看看