juqery 下拉加载数据
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 下拉加载数据的更多相关文章
- iscroll5 上拉,下拉 加载数据
我这里的思路是上拉时候只是加载第一页的内容,可根据实际情况修改其中的代码.请勿照搬.样式没怎么调,可以加载gif动画.1.没有数据时候,下拉可以加载数据.2.没有数据时候,点击也可以加载数据.3.其余 ...
- Jquery手机下拉刷新,下拉加载数据
一.Jquery手机下拉刷新,下拉加载数据.附加有源码 <!DOCTYPE html> <html> <head> <title>手机</titl ...
- 关于MJRefresh的下拉加载数据bug
当没有更多数据的时候显示NoMoreData 我的理解是先结束刷新再显示没有更多 今天之前一直没发现有问题 贴之前的代码 [self.collectionView reloadData]; [self ...
- web移动端下拉加载数据简单实现
//下拉加载在移动端会经常使用,有些小伙伴不清楚一些原理下面就简答的介绍一下 //首先需要监听window的滚动事件,下拉其实就是在监听window滚动事件 var pageNum = 1;//分页第 ...
- 手机网站下拉加载数据js(简单版)
加载内容的地方html <div class="bgcolor_f0 clearfix"> <div class="recharge"> ...
- iscroll5 版本下的 上拉,下拉 加载数据
上拉时候只是加载第一页的内容,可根据实际情况修改其中的代码. <section id="downwraper" class="nodeBottom bot0 bgf ...
- php ajax 下拉加载数据
视图 <html> <head> <title>健康知识</title> <script type="text/javascript&q ...
- Ajax 下拉加载数据
$(document).scroll(function() { var pageHeight = $(document).height()-$(window).height(); var bodySc ...
- ASP.NET仿新浪微博下拉加载更多数据瀑布流效果
闲来无事,琢磨着写点东西.貌似页面下拉加载数据,瀑布流的效果很火,各个网站都能见到各式各样的展示效果,原理大同小异.于是乎,决定自己写一写这个效果,希望能给比我还菜的菜鸟们一点参考价值. 在开始之前, ...
随机推荐
- SharePoint Excel Service - Couldn't Open the Workbook.
Error meesage: "Couldn't Open the Workbook. Wow, That's a big workbook. Unfortunately, we can't ...
- MUI框架开发HTML5手机APP(二)--页面跳转传值&底部选项卡切换
概 述 JRedu 在上一篇博客中,我们学习了如何使用Hbuilder创建一个APP,同时如何使用MUI搭建属于自己的第一款APP,没有学习的同学可以戳链接学习: http://www.cnblo ...
- GoAccess日志分析工具
1.1 GoAccess简介 GoAccess是一个非常良心的开源软件,它的良心之处体现在如下方面: 1)安装简单: 2)操作容易: 3)界面酷炫: GoAccess 官网 https://goacc ...
- ionic ion-tab图标修改, 自定义tab图标
遇到需要自定义tab图标很简单, 只需要自定义相应的css就可以了, 这里要注意的是如何调整背景图片的大小. <ion-view hide-back-button="false&quo ...
- 运行Keras版本的Faster R-CNN(1)
Keras版本的Faster R-CNN源码下载地址:https://github.com/yhenon/keras-frcnn下载以后,用PyCharm打开(前提是已经安装了Tensorflow-g ...
- http范围请求
基于范围请求 可以实现 断点续传和多线程分片下载 HTTP/1.1之后才支持,需要双端都支持 服务端头信息中有 Accept-Ranges:bytes 表明服务器支持范围请求 curl -I &quo ...
- Ubuntu18.04下可以完美运行Quake3 Arena
安装 其实很早就知道Linux下面可以跑Quake3, 但是一直没有付诸行动, 在硬盘上躺了很多年的Quake III Arena, 和Brood一起从来不舍得删, 昨天终于想起来试试. 安装很简单, ...
- 查看哪个用户登录过服务器 记录 时间 和 ip
who /var/log/wtmp 1>wtmp 一个用户每次登录进入和退出时间的永久纪录
- 12款 JavaScript 表格控件(DataGrid)
JavaScript 表格控件可以操作大数据集的 HTML表格,提供各种功能,如分页.排序.过滤以及行编辑.在本文中,我们整理了13个最好的 JavaScript 表格插件分享给开发人员,开发者可以很 ...
- 【iCore4 双核心板_ARM】例程三十八:DSP MATH库测试
实验现象: 核心代码: int main(void) { /* USER CODE BEGIN 1 */ int i,j; int res; ]; ; /* USER CODE END 1 */ /* ...