html  代码  一开始是需要显示的第一页

<div class="hot-product f15 fixed-Width clearfix" id="goods2">
<volist name="goods" id="goods_vo">
<div class="item2">
<div class="H_shangpin" style="background: url('{$goods_vo['banner'][0]}') no-repeat center ;background-size: contain"></div>
<div class="item3">
<p class="H_xianzhi">【{$goods_vo['fenlei']}】{$goods_vo['title']}</p>
<p class="color-red">
<span>¥{$goods_vo['pay']}</span>
<i class="color-b5 h_commodity fr"><del>¥{$goods_vo['yuan_pay']}</del></i>
</p>
<div class="clearfix shangpinming">
<p class="color-b5 h_commodity fl"><span>{$goods_vo['weizhi']}</span><span>{$goods_vo['shang_name']}</span></p>
<p class="fr color-b5 h_commodity ">{$goods_vo['time']}</p>
</div>
</div>
</div>
</volist>
</div>

自动监听下拉,当往下拉的时候就开始访问你指定的控制器

/*下拉分页*/
var nextp = "{$nextp}";//第几页
var oknext = 1;//加载开关
$(window).scroll(function () {
var di = $(window).scrollTop();//获取当前滚动条的位置
var ph = $(window).height();//当前窗口高度
di = di + ph;//最高拉到多少
var h = $(document).height();//允许多长滚动条
if (h - di < 100) {
if (nextp > 0 && oknext == 1) {
oknext = 0;
$.post("{:U('Index/goods')}", {p:nextp}, function (v) {//指定访问的控制器
if(v.index == 2){//这里我是做了一个判断,当需要一排显示两个就走if 当需要一排显示一个的时候就走else
if (v.status) {
oknext = 1;
nextp = v.nextp;
var list = v.list;
//console.log(list);
var html = '';
for (var i = 0; i < list.length; i++) {
html +='<div class="item2">'+
'<div class="H_shangpin" style="background: url('+list[i]['banner'][0]+') no-repeat center ;background-size: contain"></div>'+
'<div class="item3"><p class="H_xianzhi">【'+list[i]['fenlei']+'】'+list[i]['title']+'</p>'+
'<p class="color-red"><span>¥'+list[i]['pay']+'</span>'+
'<i class="color-b5 h_commodity fr"><del>¥'+list[i]['yuan_pay']+'</del></i>'+
'</p>'+
'<div class="clearfix shangpinming">'+
'<p class="color-b5 h_commodity fl"><span>'+list[i]['weizhi']+'</span><span>'+list[i]['shang_name']+'</span></p>'+
'<p class="fr color-b5 h_commodity ">'+list[i]['time']+'</p>'+
'</div>'+
'</div>'+
'</div>'; }
$("#goods2").append(html);
}
}else{
if (v.status) {
oknext = 1;
nextp = v.nextp;
var list = v.list;
var html = '';
for (var i = 0; i < list.length; i++) {
html +='<div class="clearfix H2_pad">'+
'<div class="H2_shangpin fl" style="background: url('+list[i]['banner'][0]+') no-repeat center ;background-size: cover"></div>'+
'<div class="H2_xinxi fl">'+
'<div class="H2_xianzhi">【'+list[i]['fenlei']+'】'+list[i]['title']+'</div>'+
'<div><span class="color-red">¥'+list[i]['pay']+'</span><span class="color-b5 h_commodity fr">'+list[i]['time']+'</span>'+
'</div>'+
'<div class="color-b5 h_commodity">'+
'<del>¥'+list[i]['yuan_pay']+'</del> <span class="fr"><i class="ICON-tousu h_tousu"></i>'+
'<i class="ICON-fen-LOVE '+list[i]['love']+'" data-guanzhu-id="'+list[i]['id']+',2"></i> </span>'+
'</div>'+
'</div>'+
'</div>'
}
$("#goods1").append(html);
}
} }, 'json'); } }
});

控制器方法

/*
**全部商品
**
***/
public function goods(){
$p = I('p',1);
$where['status'] = 1;
if(I('id') != 0){
$where['fenlei_id'] = I('id');
}
$this->index = M('xinxi_goods_if')->getField('index');//首页商品显示问题 单排显示1 还是双排显示2
$count = M('xinxi_goods')->where($where)->count();
$goods = M('xinxi_goods')->where($where)->field('id,title,ben_fenlei_id,uid,weizhi_id,yuan_pay,pay,banner,time,num,admin_user')->order('time DESC')->page($p,6)->select();
$nextpage=$count/6>$p?$p+1:'';
if($p == 1){//第一页的时候显示页面并显示第一个的数据
$this->nextp=$nextpage;
foreach($goods as $k=>$r){
$goods[$k]['time'] = get_date($r['time']);
$goods[$k]['banner'] = explode(',',$r['banner']);
/*商铺店名*/
if(!$r['uid']){
$goods[$k]['shang_name'] = $r['admin_user'];
}else{
$name = get_yonghu($r['uid'],'shang_name');
if(!$name){
$goods[$k]['shang_name'] = '';
}else{
$goods[$k]['shang_name'] = $name;
}
}
/*商品分类*/
$goods[$k]['fenlei'] = M('xinxi_fenlei')->where(array('id'=>$r['ben_fenlei_id']))->getField('title');
/*商城位置ID*/
$goods[$k]['weizhi'] = M('xinxi_weizhi')->where(array('id'=>$r['weizhi_id']))->getField('title');
$guanzhu_where['status'] = 1;
$guanzhu_where['shibie'] = 2;
$uid = session('uid');
if($uid != ''){
$guanzhu_where['uid'] = $uid;
$guanzhu_id = M('xinxi_guanzhu')->where($guanzhu_where)->getField('goods_user');
if($guanzhu_id == $r['id']){
$goods[$k]['love'] = 'active';
}else{
$goods[$k]['love'] = '';
}
}else{
$goods[$k]['love'] = '';
}
}
$this->assign('goods',$goods);
$this->display();
}else{
//第二页的时候就开始返回json数据
//并显示抛回这是第几页
$this->nextp=$nextpage;
foreach($goods as $k=>$r){
$goods[$k]['time'] = get_date($r['time']);
$goods[$k]['banner'] = explode(',',$r['banner']);
/*商铺店名*/
if(!$r['uid']){
$goods[$k]['shang_name'] = $r['admin_user'];
}else{
$name = get_yonghu($r['uid'],'shang_name');
if(!$name){
$goods[$k]['shang_name'] = '';
}else{
$goods[$k]['shang_name'] = $name;
}
}
/*商品分类*/
$goods[$k]['fenlei'] = M('xinxi_fenlei')->where(array('id'=>$r['ben_fenlei_id']))->getField('title');
/*商城位置ID*/
$goods[$k]['weizhi'] = M('xinxi_weizhi')->where(array('id'=>$r['weizhi_id']))->getField('title');
$guanzhu_where['status'] = 1;
$guanzhu_where['shibie'] = 2;
$uid = session('uid');
if($uid != ''){
$guanzhu_where['uid'] = $uid;
$guanzhu_id = M('xinxi_guanzhu')->where($guanzhu_where)->getField('goods_user');
if($guanzhu_id == $r['id']){
$goods[$k]['love'] = 'active';
}else{
$goods[$k]['love'] = '';
}
}else{
$goods[$k]['love'] = '';
}
}
$data['index'] = M('xinxi_goods_if')->getField('index');//首页商品显示问题 单排显示1 还是双排显示2
$data['list']=$goods;
$data['nextp']=$nextpage;
$data['status']=1;
echo json_encode($data);
}
}

juqery 下拉加载数据的更多相关文章

  1. iscroll5 上拉,下拉 加载数据

    我这里的思路是上拉时候只是加载第一页的内容,可根据实际情况修改其中的代码.请勿照搬.样式没怎么调,可以加载gif动画.1.没有数据时候,下拉可以加载数据.2.没有数据时候,点击也可以加载数据.3.其余 ...

  2. Jquery手机下拉刷新,下拉加载数据

    一.Jquery手机下拉刷新,下拉加载数据.附加有源码 <!DOCTYPE html> <html> <head> <title>手机</titl ...

  3. 关于MJRefresh的下拉加载数据bug

    当没有更多数据的时候显示NoMoreData 我的理解是先结束刷新再显示没有更多 今天之前一直没发现有问题 贴之前的代码 [self.collectionView reloadData]; [self ...

  4. web移动端下拉加载数据简单实现

    //下拉加载在移动端会经常使用,有些小伙伴不清楚一些原理下面就简答的介绍一下 //首先需要监听window的滚动事件,下拉其实就是在监听window滚动事件 var pageNum = 1;//分页第 ...

  5. 手机网站下拉加载数据js(简单版)

    加载内容的地方html <div class="bgcolor_f0 clearfix"> <div class="recharge"> ...

  6. iscroll5 版本下的 上拉,下拉 加载数据

    上拉时候只是加载第一页的内容,可根据实际情况修改其中的代码. <section id="downwraper" class="nodeBottom bot0 bgf ...

  7. php ajax 下拉加载数据

    视图 <html> <head> <title>健康知识</title> <script type="text/javascript&q ...

  8. Ajax 下拉加载数据

    $(document).scroll(function() { var pageHeight = $(document).height()-$(window).height(); var bodySc ...

  9. ASP.NET仿新浪微博下拉加载更多数据瀑布流效果

    闲来无事,琢磨着写点东西.貌似页面下拉加载数据,瀑布流的效果很火,各个网站都能见到各式各样的展示效果,原理大同小异.于是乎,决定自己写一写这个效果,希望能给比我还菜的菜鸟们一点参考价值. 在开始之前, ...

随机推荐

  1. WPF 实现窗体拖动

    C# 实现代码 this.Loaded += (r, s) => { this.MouseDown += (x, y) => { if (y.LeftButton == MouseButt ...

  2. grid - 网格项目层级

    网格项目可以具有层级和堆栈,必要时可能通过z-index属性来指定. 1.在这个例子中,item1和item2的开始行都是1,item1列的开始是1,item2列的开始是2,并且它们都跨越两列.两个网 ...

  3. DockerSwarm获取Token与常用命令

    一.Token相关 Join tokens是允许一个节点加入集群的密钥.有两种可用的不同的join tokens,一个是用作worker角色,另一个是用作manager角色.在执行swarm join ...

  4. linux性能压测工具

    http://benjr.tw/532 http://blog.yufeng.info/archives/2023 https://www.cnblogs.com/zhoujinyi/archive/ ...

  5. SQL Server里如何处理死锁

    在今天的文章里,我想谈下SQL Server里如何处理死锁.当2个查询彼此等待时会发生死锁,没有一个查询可以继续它们的操作.首先我想给你大致讲下SQL Server如何处理死锁.最后我会展示下SQL ...

  6. jQuery(三) javascript跨域问题(JSONP解决)

    加油~ --WH 一.什么是javascript跨域问题? 域:服务器域名,唯一标识(协议,域名,端口)必须保证一致,说明域相同 跨域:在一个服务器上,去访问另一个服务器上,并且得到另一个服务器返回回 ...

  7. python中字符串前的r什么意思

    Python中,u表示unicode string,表示使用unicode进行编码,没有u表示byte string,类型是str,在没有声明编码方式时,默认ASCI编码.如果要指定编码方式,可在文件 ...

  8. npm install 项目安装遇到问题

    npm cache clean/clear --force

  9. HTTP 05 安全

    TCP 打包时加密, 报文传输时 加密 通过证书来判断是否是可以访问的客户端/服务器. 公开秘钥 进行加密, 随便被人知道 私有秘钥 进行解密, 自己保留 http + 加密 + 认证 + 完整性保护 ...

  10. 更改Nginx网站根目录以及导致的403 forbidden问题解决

    版权声明:本文为博主原创文章,未经博主允许不得转载. 一.更改根目录 Nginx默认网站根目录为/usr/local/nginx/html,要将它改成/home/fuxiao/www   更改方法: ...