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

2025-05-27 0 52

一、HTML

?

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

二、JS

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

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23
<!-- 拼接图片 -->

<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>

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84
<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

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26
#这里是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));

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49
# 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数据表格实现数据分页渲染代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持快网idc。

原文链接:https://www.cnblogs.com/yachyu/p/10768252.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 php+layui数据表格实现数据分页渲染代码 https://www.kuaiidc.com/71116.html

相关文章

发表评论
暂无评论