https://blog.csdn.net/a898712940/article/details/78545599?utm_source=blogxgwz8

适用范围:thinkphp3.2和thinkphp5.0

php代码:

  1. public function myorder_list(Request $request){
  2.  
  3. $uid = $this->uid;
  4. $where = array(
  5. 'uid' => $uid,
  6. );
  7. $page = $this->request->param('page') ? $this->request->param('page') : 1; //获取请求的页数
  8. $num = 10;//请求条数
  9. $order_list = db('shop_order')
  10. ->alias('so')
  11. ->join(config('database.prefix').'shop_order_goods sog','so.id = sog.orderid')
  12. ->field('so.ordersn,so.pay_price,sog.id,sog.orderid,sog.goodsid,sog.goods_name,sog.goods_price,sog.thumb,sog.total')
  13. ->where($where)
  14. ->order("so.createtime", 'desc')
  15. ->page($page,$num)
  16. ->select();
  17.  
  18. foreach ($order_list as $k=>$v){
  19. $order_list[$k]['total'] = db('member_video')->where('orderid',$v['id'])->count();
  20. }
  21. //判断是否为ajax请求,获取更多数据
  22. $count = count($order_list);
  23. if($this->request->isPost()){
  24. if($count<$num){//判断是否到尾页
  25. $order_list[]['id']=0;//到尾页返回0
  26. }
  27. return json($order_list);//将数组转成json格式返回
  28. exit;//中断后面的display()
  29. }
  30. $this->assign('order_list',$order_list);
  31. $this->assign(['num'=>$num,'count'=>$count]);
  32. return $this->view->fetch();
  33. }

html代码:

  1. <ul class="orderlist-wrap" >
  2. {if !empty($order_list)}
  3. {volist name="order_list" id="vo"}
  4. <li class="orderlist">
  5. <a class="orderlist-a" href="">
  6. <img src="{if !empty($vo.thumb)} {$vo.thumb} {else} /uploads/videos/20171109/1627f7f77cefa595bc0ea4b95bdd8f30.jpg {/if}" />
  7. <span class="orderlist-txt-l">
  8. <span class="orderlist-txt-ls1">{$vo.ordersn}</span>
  9. <span class="orderlist-txt-ls2">
  10. <i>数量:{$vo.total}</i>
  11. <i>总价:<span class="iconfont13 icon-rmb"></span>{$vo.pay_price}</i>
  12. </span>
  13. </span>
  14. </a>
  15. <span class="orderlist-txt-r">
  16. <span class="orderlist-txt-r1">待评价</span>
  17. <a class="orderlist-txt-r2">评价</a>
  18. </span>
  19. </li>
  20. {/volist}
  21. {else/}
  22. <div class="tomore" id="nocell" style="text-align: center;line-height: .55rem;" >暂无订单记录...</div>
  23. {/if}
  24. </ul>
  25. {if $count egt $num}
  26. <div class="tomore" id="getmore" style="text-align: center;line-height: .55rem;color: #0061ff;">查看更多<i class="iconfont12 icon-gengduo1"></i></div>
  27. {/if}
  28.  
  29. <!-- 请求的页数-->
  30. <input type="hidden" name="" id="page" value="2">

js代码:

  1. <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
  2. <script type="text/javascript">
  3. var page = $("#page").val(); //从第二页开始获取数据
  4. $("#getmore").click(function(){
  5. $.ajax({
  6. type: "post",
  7. dataType: "json",
  8. url: '{:url("m/member/myorder_list")}',
  9. data: {page:page},
  10. success: function(data) {
  11. //console.log(data);
  12. var str = "";//定义变量保存内容
  13. $.each(data,function(index,array){
  14. if (array['id']){
  15. str += '<li class="orderlist">'+
  16. '<a class="orderlist-a" href="">'+
  17. '<img src="'+array['thumb']+'"/>'+
  18. '<span class="orderlist-txt-l">'+
  19. '<span class="orderlist-txt-ls1">'+array['goods_name']+'</span>'
  20. +'<span class="orderlist-txt-ls2">'
  21. +'<i>数量:'+array['total']+'</i>'
  22. +'<i>总价:<span class="iconfont13 icon-rmb"></span>'+array['goods_price']*array['total']+'</i>'+
  23. '</span>'+
  24. '</span>'+
  25. '</a>'+
  26. '<span class="orderlist-txt-r">'+
  27. '<span class="orderlist-txt-r1">'+'待评价'+'</span>'+
  28. '<a class="orderlist-txt-r2">'+'评价'+'</a>'+
  29. '</span>'+
  30. '</li>';
  31. }else{
  32. $("#getmore").html("没有更多内容了..");
  33. }
  34. });
  35. $(".orderlist-wrap").append(str); //把HTML添加到容器
  36. var pageval = page++;//页数+1
  37. $("#page").val(pageval);
  38. }
  39. });
  40. });
  41. </script>

thinkphp+ajax 实现点击加载更多数据的更多相关文章

  1. ajax点击加载更多数据图片(预加载)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. jQuery+php+Ajax文章列表点击加载更多功能

    jQuery+php+Ajax实现的一个简单实用的文章列表点击加载更多功能,点击加载更多按钮,文章列表加载更多数据,加载中有loading动画效果. js部分: <script type=&qu ...

  3. PHP+Ajax点击加载更多列表数据实例

    一款简单实用的PHP+Ajax点击加载更多列表数据实例,实现原理:通过“更多”按钮向服务端发送Ajax请求,PHP根据分页参数查询将最新的几条记录,数据以JSON形式返回,前台Query解析JSON数 ...

  4. PHP+Ajax点击加载更多内容 -这个效果好,速度快,只能点击更多加载,不能滚动自动加载

    这个效果好,速度快,只能点击更多加载,不能滚动自动加载 一.HTML部分 <div id="more"> <div class="single_item ...

  5. Yii 1开发日记 -- Ajax实现点击加载下一页

    功能实现:先输出一页的内容,然后点击加载下一页,如图 1.控制器中 /** * 消费记录:列出用户购买章节的记录 */ public function actionMyPayHis() { //点击加 ...

  6. Spring+Hibernate+struts2+JPA 注解+跨域//完成手机端点击加载更多 下拉加载更多

    一.使用IDEA新建一个maven项目(student) 1.1.0编写pom文件,添加项目所需要的包 <?xml version="1.0" encoding=" ...

  7. Jquery点击加载更多

    一.点击加载更多有点像分页获取数据类似,下面是本人写的一个简单的小例子 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...

  8. IOS - UITableView分批显示数据 实现点击加载更多

    Phone屏幕尺寸是有限的,如果需要显示的数据很多,可以先数据放到一个table中,先显示10条,table底部有一察看更多选项,点击察看更多查看解析的剩余数据.基本上就是数据源里先只放10条, 点击 ...

  9. tableView中的“点击加载更多”点击不到

    假设当前的tableView是_tableView,则可以这样设置 _tableView.contentInset = UIEdgeInsetsMake(0, 0, 100, 0); 该属性用于设置当 ...

随机推荐

  1. Java 基础数据类型

    Java 提供的基础数据类型(也称内置数据类型)包含:整数类型.浮点类型.字符类型.布尔类型. 整数类型 整数类型变量用来表示整数的数据类型.整数类型又分为字节型(byte).短整型(short).整 ...

  2. JAVA入门各种API参考

    java sdk: https://docs.oracle.com/javase/8/docs/api/ servlet api: http://tomcat.apache.org/tomcat-8. ...

  3. JS 基本的介绍

    JS中的注释   HTML的注释:<!—注释内容-->   CSS注释:/* 注释 */   JavaScript的注释:// 或 /*  多行注释 */ 变量 1.变量的概念 变量是变化 ...

  4. WannaCry结束了? 安专家注册域名掐断病毒传播

    腾讯科技讯,(韩依民) 5 月 13 日,席卷全球的勒索病毒 WannaCry(也被称作 WanaCrypt 或 WCry),在今日晚间被互联网安全人员找到阻止其传播的方法. 据北京云纵信息技术有限公 ...

  5. 移动端适配(绝对单位、相对单位、CSS像素、物理像素、逻辑像素、设备像素比、PPI、Viewport)

    在某公司做了一次分享,主题是‘移动端和pc端开发的区别’.可以说,这总结的原版就是在这样的契机下完成的.因为我只是习惯了移动端就应该那么写(设置viewport等),要是让我给大家分条讲下所以然,还真 ...

  6. requests 返回 521

    网页端抓数据免不了要跟JavaScript打交道,尤其是JS代码有混淆,对cookie做了手脚.找到cookie生成的地方要费一点时间. 那天碰到这样一个网页,用浏览器打开很正常.然而用request ...

  7. 简介、变量、常数、if、基础数据类型、注释、input()

    ​ ### 1.python的历史 python2和python3的区别 python2 源码不统一,重复代码 python 源码统一,没有重复代码 2004 Django框架的诞生 2.python ...

  8. Spring 框架中Http请求处理流程

    Spring Web http request请求流程: 首先介绍这边你需要知道的继承体系,DispacherServlet继承自FrameworkServlet,FrameworkServlet继承 ...

  9. thinkphp 虚拟模型

    虚拟模型是指虽然是模型类,但并不会真正的操作数据库的模型.有些时候,我们建立模型类但又不需要进行数据库操作,仅仅是借助模型类来封装一些业务逻辑,那么可以借助虚拟模型来完成.虚拟模型不会自动连接数据库, ...

  10. python Xls文档读写

    1.模块安装 2.python 代码 import xlrd import xlwt import datetime def set_style(name,height,format,bold=Fal ...