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. ClickHouse高可用集群的配置

    上一篇文章写过centos 7下clickhouse rpm包安装和基本的目录结构,这里主要介绍clickhouse高可用集群的部署方案,因为对于默认的分布式表的配置,每个分片只有一份,这样如果挂掉一 ...

  2. Pandas 使用笔记

    创建空的数据框: import pandas as pd df = pd.DataFrame(columns = ["ebayno", "p_sku", &qu ...

  3. VMWare 下安装 MSDN版 MS-DOS 6.22

    最近有些怀旧,刚从孔夫子旧书网淘回一本<Borland 传奇>,里面讲到了很多DOS时代的经典软件,特别想尝试一下~比如:Turbo Pascal.SideKick.Borland C/C ...

  4. Docker 安装和基础用法

    理解Docker(1):Docker 安装和基础用法 本系列文章将介绍Docker的有关知识: (1)Docker 安装及基本用法 (2)Docker 镜像 (3)Docker 容器的隔离性 - 使用 ...

  5. Android设置屏幕旋转后保存数据

    1.onCreate()方法中最后判断需要保存的状态值 if(savedInstanceState != null){ mCurrentIndex = savedInstanceState.getIn ...

  6. Guava Preconditions 工具参数前置校验

    guava 提供 Preconditions  作为代码校验的工具类,用来简化开发中对代码的校验或预处理,在逻辑开始前进行合理性校验,避免参数传入过深导致的数据错误. 并且能够在不符合校验条件的地方, ...

  7. Hive 根据表中某个字段动态分区 以及临时表创建

    使用hive储存数据时,需要对做分区,如果从kafka接收数据,将每天的数据保存一个分区(按天分区),保存分区时需要根据某个字段做动态分区,而不是傻傻的将数据写到某一个临时目录最后倒入到某一个分区,这 ...

  8. v2ray和ss的安装资料整理

    v2ray: 1. https://yuan.ga/v2ray-complete-tutorial/ 2. https://toutyrater.github.io/ 推荐使用:v2ray,会比ss快 ...

  9. [elk]kafka集群

    kafka高可用 并发写 每一个分区都是一个顺序的.不可变的消息队列, 并且可以持续的添加.分区中的消息都被分了一个序列号,称之为偏移量(offset),在每个分区中此偏移量都是唯一的. 并发读 数据 ...

  10. Jquery on方法绑定事件后执行多次

    每次绑定前先取消上次的绑定. $('#sub').unbind('click').click(function () { ... });