
离线 TA的专栏
- 打卡等级:热心大叔
- 打卡总天数:204
- 打卡月天数:0
- 打卡总奖励:3120
- 最近打卡:2023-08-27 04:26:40
|
一、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数据表格实现数据分页渲染代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持晓枫资讯。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:  进行删除处理。
4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
|