• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    php+layui数据表格实现数据分页渲染代码

    一、HTML

    table class="layui-hide layui-table" id="spu-data">/table>

    二、JS

    说明:需要引入layui中的table和laytpl模板引擎,laytpl可以自定义事件及自定义数据字段等

    !-- 拼接图片 -->
    script type="text/html" id="pimg">
     img class="img" onmouseover="divIn(event)" onmouseout="divOut(event)" onmousemove="divIn(event)" src="__PUBLIC__/{{d.pimgurl}}t_{{d.pimgname}}" alt="">
    /script>
    
    !-- 查看详情按钮 -->
    script type="text/html" id="spu_detail">
     button class="layui-btn layui-btn-xs layui-btn-primary spu_detail" artnum="{{d.artnum}}" value="{{d.basic_id}}" onclick="spuDetail(event)">查看详情/button>
    /script>
    
    script type="text/html" id="hotcake_color">
     {{# if (d.hotcake === '超级爆款') { }} 
      span style="display: block;background-color: #CCFFCC;">{{ d.hotcake }}/span>
     {{# } else if(d.hotcake === '大爆款') { }} 
      span style="display: block;background-color: #99CCCC;">{{ d.hotcake }}/span> 
     {{# } else if(d.hotcake === '小爆款') { }} 
      span style="display: block;background-color: #FFCCCC;">{{ d.hotcake }}/span> 
     {{# } else if(d.hotcake === '热销款') { }} 
      span style="display: block;background-color: #FFFFCC;">{{ d.hotcake }}/span> 
     {{# } else { }} 
      span style="display: block;background-color: #CCFFFF;">{{ d.hotcake }}/span> 
     {{# } }} 
    /script>
    script type="text/javascript">
    
    layui.use(['form','laydate','layer','table','laytpl'],function(){
     var laydate = layui.laydate;
     var layer = layui.layer;
     var table = layui.table;
     var laytpl = layui.laytpl;
    
      //---SPU数据---------------------------------------------
     var spu_table = table.render({
      elem: '#spu-data',   //html中table窗口的id
      height: 800,
      url: '__URL__/spu_data', //后台接口
      toolbar: true,
      loading: true,
      text: {
       none: '空空如也'
      },
      title: 'spu数据',
      size: 'sm',
      page: {
       layout: ['count', 'prev', 'page', 'next', 'limit', 'refresh', 'skip'],
       limit: 20,
       limits: [20,30,50,100,200,5000]
      },
      cols: [[
        {field:'n', title: 'i', width: 55},
        {field:'', title: '图', width: 31, templet: '#pimg'},     // templet 引用laytpl中的自定义模板
        {field:'', title: '查看详情', width: 120, templet: '#spu_detail'},  // 引用laytpl中的自定义模板
        {field:'artnum', title: '货号', sort: true},
        {field:'gcolor', title: '颜色组', sort: true},
        {field:'cate', title: '品类', sort: true},
        {field:'price', title: '业绩', sort: true},
        {field:'sales', title: '销量', sort: true},
        {field:'hotcake', title: '热销程度', templet: '#hotcake_color', sort: true},
        {field:'sumcost', title: '商品成本', sort: true}
      ]]
     });
    
    // 搜索重载数据
     $('#spudata_search').click(function(){
      // 获取日期的值
      var date = $('#spusearch_date').val();
      if (!date) {
       layer.msg('请选择日期区间搜索', {
        time: 2000
       });
       return false;
      }
    
      var perfor_val = $('#perfor_val').val();;
      var hot_type = $('#hot_type').val();
      var artnum = $('#artnum').val();
      var cate_id = $('#cate_id').val();
    
      // 只选其一条件
      if (perfor_val  hot_type) {
       layer.msg('业绩区间和爆款类型只选其一', {
        time: 2000
       });
       return false;
      }
    
      // 数据重载
      spu_table.reload({
       // 发送条件
       where: {
        artnum: artnum,
        perfor_val: perfor_val,
        hot_type: hot_type,
        cate_id: cate_id,
        date: date,
        act: 'reload'
       },
       page: {
        layout: ['count', 'prev', 'page', 'next', 'limit', 'refresh', 'skip'],
        curr: 1
       }
      });
    
     })
    
    }) 
    /script>

    三、PHP

    #这里是PHP类中主要的配合步骤
    
    # 接收layui发送的limit
    if (trim($_GET['limit'])) {
     $limit = trim($_GET['limit']);
    }else{
     $limit = 15;
    }
    
    # 按某字段排序,$rows为数据数组
    $sort_num = array_column($rows,'num');
    array_multisort($sort_num,SORT_DESC,$rows, SORT_DESC);
    
    # 调用自定义分页函数
    $datas = array();
    $datas = showpage($rows,$limit);
    
    $items = array();
    
    # 返回layui数据格式
    $items['data'] = $datas['rows'];
    $items['code'] = 0;
    $items['msg'] = 'ok';
    $items['count'] = $datas['tot'];
    
    exit(json_encode($items));
    # showpage函数
    
    function showpage($rows,$count){ 
     $tot = count($rows); // 总数据条数
    
     if ($_GET['page']) { //获取当前页码
      $page = $_GET['page'];
     }else{
      $page = 1;
     }
    
     // $count = $count; # 每页显示条数
    
     $countpage = ceil($tot/$count); # 计算总共页数
    
     $start = ($page-1)*$count; # 计算每页开始位置
    
     $datas = array_slice($rows, $start, $count); # 计算当前页数据
    
     # 获取上一页和下一页
     if ($page > 1) {
      $uppage = $page-1;
     }else{
      $uppage = 1;
     }
    
     if ($page  $countpage) {
      $nextpage = $page+1;
     }else{
      $nextpage = $countpage;
     }
    
     $pages['countpage'] = $countpage;
     $pages['page'] = $page;
     $pages['uppage'] = $uppage;
     $pages['nextpage'] = $nextpage;
     $pages['tot'] = $tot;
    
     //循环加入序号 , 避免使用$i引起的序号跳位
     $n = 1;
     foreach ($datas as $data) {
      $data['n'] = $n;
      $n++;
     }
     
     $pages['rows'] = $datas;
    
     return $pages;
    }

    以上这篇php+layui数据表格实现数据分页渲染代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

    您可能感兴趣的文章:
    • thinkphp5+layui实现的分页样式示例
    • layui+jquery支持IE8的表格分页方法
    • layui 数据表格+分页+搜索+checkbox+缓存选中项数据的方法
    • layui table 获取分页 limit的方法
    • 浅谈layui分页控件field参数接收对象的问题
    • 浅谈layui框架自带分页和表格重载的接口解析问题
    • Layui之table中的radio在切换分页时无法记住选中状态的解决方法
    • layui表格分页 记录勾选的实例
    • Layui实现数据表格默认全部显示(不要分页)
    上一篇:layui数据表格自定义每页条数limit设置
    下一篇:PHP判断当前使用的是什么浏览器(推荐)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    php+layui数据表格实现数据分页渲染代码 php+layui,数据,表格,实现,