找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1431|回复: 0

[分享] 织梦dedecms首页列表页ajax点击下拉加载更多文章瀑布流效果

[复制链接]
发表于 2018-7-29 09:54:28 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
织梦dedecms实现点击下拉加载更多主要用到ajax技术。具体步骤如下:
一、首先找到并打开/plus/list.PHP文件,在里面找到如下代码:
require_once(dirname(__FILE__)."/../include/common.inc.php");
在这段代码下面添加以下代码:

  1. //列表页瀑布流无限加载代码
  2. if(isset($_GET['ajax'])){
  3.     $typeid = isset($_GET['typeid']) ? intval($_GET['typeid']): 0;//传递过来的分类ID
  4.     $page = isset($_GET['page']) ? intval($_GET['page']): 0;//页码
  5.     $pagesize = isset($_GET['pagesize']) ? intval($_GET['pagesize']): 15;//每页多少条,也就是一次加载多少条数据
  6.     $start = $page>0 ? ($page-1)*$pagesize : 0;//数据获取的起始位置。即limit条件的第一个参数。
  7.     $typesql = $typeid ? " WHERE typeid=$typeid" : '';//这个是用于首页实现瀑布流加载,因为首页加载数据是无需分类的,所以要加以判断,如果无需
  8.     $total_sql = "SELECT COUNT(id) as num FROM `dede_archives` $typesql ";
  9.     $temp = $dsql->GetOne($total_sql);
  10.     $total = 0;//数据总数
  11.     $load_num =0;
  12.     if(is_array($temp)){
  13.         $load_num= round(($temp['num']-15)/$pagesize);//要加载的次数,因为默认已经加载了
  14.         $total = $temp['num'];
  15.     }
  16.     $sql = "SELECT a.*,t.typedir,t.typename,t.isdefault,t.defaultname,t.namerule,
  17.     t.namerule2,t.ispart, t.moresite,t.siteurl,t.sitepath
  18.     FROM `dede_archives` as a JOIN `dede_arctype` AS t ON a.typeid=t.id $typesql ORDER BY id DESC LIMIT $start,$pagesize";
  19.     $dsql->SetQuery($sql);
  20.     $dsql->Execute('list');
  21.     $statu = 0;//是否有数据,默认没有数据
  22.     $data = array();
  23.     $index = 0;
  24.     while($row = $dsql->GetArray("list")){
  25.         $row['info'] = $row['info'] = $row['infos'] = cn_substr($row['description'],160);
  26.         $row['id'] =  $row['id'];
  27.         $row['filename'] = $row['arcurl'] = GetFileUrl($row['id'],
  28.         $row['typeid'],$row['senddate'],$row['title'],$row['ismake'],
  29.         $row['arcrank'],$row['namerule'],$row['typedir'],$row['money'],
  30.         $row['filename'],$row['moresite'],$row['siteurl'],$row['sitepath']);
  31.         $row['typeurl'] = GetTypeUrl($row['typeid'],$row['typedir'],
  32.         $row['isdefault'],$row['defaultname'],$row['ispart'],
  33.         $row['namerule2'],$row['moresite'],$row['siteurl'],$row['sitepath']);
  34.         if($row['litpic'] == '-' || $row['litpic'] == ''){
  35.             $row['litpic'] = $GLOBALS['cfg_cmspath'].'/images/defaultpic.gif';
  36.         }
  37.         if(!preg_match("#^http:\/\/#i", $row['litpic']) &&$GLOBALS['cfg_multi_site'] == 'Y'){
  38.             $row['litpic'] = $GLOBALS['cfg_mainsite'].$row['litpic'];
  39.         }
  40.         $row['picname'] = $row['litpic'];//缩略图
  41.         //$row['stime'] = GetDateMK($row['pubdate']);
  42.         $row['stime'] = date('Y-m-d H:i', $row['pubdate']);
  43.         $row['click'] = $row['click'];
  44.         $row['typelink'] = "".$row['typename']."";//分类链
  45.         $row['fulltitle'] = $row['title'];//完整的标题
  46.         $row['shorttitle'] = $row['shorttitle'];//副标题
  47.         $row['title'] = cn_substr($row['title'], 80);//截取后的标题
  48.         $data[$index] = $row;
  49.         $index++;
  50.     }
  51.     if(!empty($data)){
  52.         $statu = 1;//有数据
  53.     }
  54.     $result =array('statu'=>$statu,'list'=>$data,'total'=>$total,'load_num'=>$load_num);
  55.     echo json_encode($result);//返回数据
  56.     exit();
  57. }
复制代码

二、然后在需要使用瀑布流无线加载的织梦dedecms模板里引用下面这个js代码(这个js大家应该不是很陌生,只要有用到JQ库函数的话一定要引用这个js):

  1. <script src="http://libs.baidu.com/jQuery/1.9.0/jquery.js"></script>
复制代码

三、并在模板底部添加以下代码:

  1. <script type="text/javascript">
  2. var loadConfig = {
  3.                 url_api:'/plus/list.php',
  4.                 typeid:{dede:field name="typeid"/},
  5.                 page:2,
  6.                 pagesize:15,  //这个就是滑动一次添加几条信息的参数设置
  7.                 loading : 0,
  8.                 }
  9. function  loadMoreApply(){
  10.     if(loadConfig.loading == 0){
  11.          var typeid = loadConfig.typeid;
  12.          var page = loadConfig.page;
  13.          var pagesize = loadConfig.pagesize;
  14.          var url = loadConfig.url_api,data={ajax:'pullload',typeid:typeid,page:page,pagesize:pagesize};
  15.          var sTop = document.body.scrollTop || document.documentElement.scrollTop, dHeight = $(document).height(), cHeight = document.documentElement.clientHeight;
  16.          console.log(dHeight);
  17.               
  18.          if (sTop + cHeight >= dHeight - cHeight) {
  19.              loadConfig.loading = 1;
  20.             function ajax(url, data) {
  21.                      
  22.                 $.ajax({url: url,data: data,async: false,type: 'GET',dataType: 'json',success: function(data) {
  23.                     addContent(data);  
  24.                 }});
  25.             }
  26.             ajax(url,data);
  27.         }
  28.     }
  29. }
  30. function addContent (rs){
  31.     if(rs.statu== 1){
  32.         var data = rs.list;
  33.         var total = rs.total;
  34.         var arr=[];
  35.         var length = data.length;
  36.         for(var i=0;i<length;i++){
  37.             arr.push('<a href="'+data[i].arcurl+'" title="'+data[i].title+'">');
  38.             arr.push('<dl class="yz_card">');
  39.             arr.push('<dt class="yz_card_dt">');
  40.             arr.push('<img src="'+data[i].picname+'" alt="'+data[i].title+'">');
  41.             arr.push('</dt>');
  42.             arr.push('<dd class="yz_card_dd">');
  43.             arr.push('<p class="yz_card_p">'+data[i].title+'</p>');
  44.             arr.push('<div class="yz_card_icon">');
  45.             arr.push('<span class="yz_comment">');
  46.             arr.push(data[i].click);                           
  47.             arr.push('<em class="yz_icon_comment"><img src="/templets/default/images/[url=http://bbs.piaoxian.net/thread-76922-1-1.html]ping[/url]luan.png" height="14"></em>');
  48.             arr.push('</span>');
  49.             arr.push('</div>');
  50.             arr.push('<div class="yz_datetime">'+data[i].stime+'</div>');
  51.             arr.push('</dd>');
  52.             arr.push('</dl>');
  53.             arr.push('</a>');
  54.         }
  55.         $('.arclist').append(arr.join(''));
  56.         loadConfig.load_num = rs.load_num;
  57.         if(total<loadConfig.page*loadConfig.pagesize || loadConfig.page > loadConfig.load_num){
  58.             window.removeEventListener('srcoll',loadMoreApply,false);
  59.         }
  60.         loadConfig.page++;
  61.         loadConfig.loading = 0;
  62.     }
  63. }
  64. function pullLoad(){
  65.     window.addEventListener('scroll', loadMoreApply, false);
  66. }
  67. pullLoad();
  68. </script>
复制代码

上面的代码中的$('.arclist').append(arr.join(''));里的arclist对应模板内列表的外框class属性。

arr.push部分对应的是列表中单篇文章的代码。

如果在首页只需把代码中的”typeid:{dede:field name="typeid"/}“ 修改为”typeid:0,“即可。

到此织梦dedecms瀑布流无限加载就实现了。

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 需要先绑定手机号

关闭

站长推荐上一条 /1 下一条

QQ|侵权投诉|广告报价|手机版|小黑屋|西部数码代理|飘仙建站论坛 ( 豫ICP备2022021143号-1 )

GMT+8, 2024-12-24 09:39 , Processed in 0.042653 second(s), 8 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表