找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1244|回复: 0

[分享] DEDECMS的首页顶客数据实时刷新

[复制链接]
发表于 2018-3-1 16:39:37 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
最近几天帮朋友仿了个网站,仿站的过程虽然要耗费很多功夫,但是也会学习到一些新知识。这不,今天又学习到了一个新知识: 我仿的这个站的顶客可以实现首页的实时刷新,而不需要全站刷新?其实这个和A5首页一样,以前没有研究过,直接下载网上的模板然后进行一些修改,但今天不行,朋友非要实现这个效果,于是还是花了一番功夫研究了下,下面是我的一些心得,希望对大家有些用处。
1)实现方法
第一步:首先创建一个空白首页文件,在里面<body>区域加入以下调用代码:
  1. <ol>  
  2.     {dede:arclist row='5' titlelen='20'}   
  3.     <li><a href="[field:arcurl/]">[field:title/]</a> <span id="diggNum[field:id/]">操作区:<a href="javascript:" onclick="javascript:postDigg('good',[field:id/])">顶</a>([field:goodpost/]) <a href="javascript:" onclick="javascript:postDigg('bad',[field:id/])">踩</a>([field:badpost/])</span></li>  
  4. <script language="javascript" type="text/javascript">getDigg([field:id/]);</script>   
  5.     {/dede:arclist}   
  6. </ol>  
复制代码

这里的<script language="javascript" type="text/javascript">getDigg([field:id/]);</script>  被加在了arclist标签里作为底层模板,是为了让每一篇文档都可以独立显示其顶和踩的状态。
第二步:在<head></head>区域内加入以下代码:
  1. <script language="javascript" type="text/javascript" src="{dede:global.cfg_cmsurl/}/include/dedeajax2.js"></script>  
  2. <script language="javascript" type="text/javascript">  
  3. function postDigg(ftype,aid)   
  4. {   
  5.     var taget_obj = document.getElementById('diggNum'+aid);   
  6.     var saveid = GetCookie('diggid');   
  7.     if(saveid != null)   
  8.     {   
  9.         var saveidsaveids = saveid.split(',');   
  10.         var hasid = false;   
  11.         saveid = '';   
  12.         j = 1;   
  13.         for(i=saveids.length-1;i>=0;i--)   
  14.         {   
  15.             if(saveids[i]==aid && hasid) continue;   
  16.             else {   
  17.                 if(saveids[i]==aid && !hasid) hasid = true;   
  18.                 saveid += (saveid=='' ? saveids[i] : ','+saveids[i]);   
  19.                 j++;   
  20.                 if(j==20 && hasid) break;   
  21.                 if(j==19 && !hasid) break;   
  22.             }   
  23.         }   
  24.         if(hasid) { alert("您已经顶过该帖,请不要重复顶帖 !"); return; }   
  25.         else saveid += ','+aid;   
  26.         SetCookie('diggid',saveid,1);   
  27.     }   
  28.     else   
  29.     {   
  30.         SetCookie('diggid',aid,1);   
  31.     }   
  32.     myajax = new DedeAjax(taget_obj,false,false,'','','');   
  33.     var url = "{dede:global.cfg_phpurl/}/digg_ajax_index.php?action="+ftype+"id="+aid;   
  34.     myajax.SendGet2(url);   
  35.     DedeXHTTP = null;   
  36. }   
  37. function getDigg(aid)   
  38. {   
  39.     var taget_obj = document.getElementById('diggNum'+aid);   
  40.     myajax = new DedeAjax(taget_obj,false,false,'','','');   
  41.     myajax.SendGet2("{dede:global.cfg_phpurl/}/digg_ajax_index.php?id="+aid);   
  42.     DedeXHTTP = null;   
  43. }   
  44. </script>
复制代码

这一段代码主要就是引入织梦系统自带的Ajax框架(dedeajax2.js) 和两个操作的函数(postDigg(ftype,aid)与getDigg(aid))
有了这两个,基本框架已经实现了!接下来要做的就是:
第三步:在/plus/ 文件夹下创建一个名为digg_ajax_index.php的文件,该文件的内容为:
  1. <?php   
  2.   /****************  
  3.     @@ 功能:用于列表中DIGG处理效果  
  4.     @@ 作者:华强℡(QQ:3421209)  
  5.     @@ 网站:模板天下(www.mobantianxia.cn)  
  6.     @@ 日期:2010-10-26  
  7. ****************/  
  8. require_once(dirname(__FILE__)."/../include/common.inc.php");   
  9.   $action = isset($action) ? trim($action) : '';   
  10. $id = emptyempty($id)? 0 : intval(preg_replace("/[^\d]/",'', $id));   
  11.   if($id < 1)   
  12. {   
  13.     exit();   
  14. }   
  15. $maintable = 'dede_archives';   
  16. if($action == 'good')   
  17. {   
  18.     $dsql->ExecuteNoneQuery("Update `$maintable` set scores = scores + {$cfg_caicai_add},goodpost=goodpost+1,lastpost=".time()." where id='$id'");   
  19. }   
  20. else if($action=='bad')   
  21. {   
  22.     $dsql->ExecuteNoneQuery("Update `$maintable` set scores = scores - {$cfg_caicai_sub},badpost=badpost+1,lastpost=".time()." where id='$id'");   
  23. }   
  24. $digg = '';   
  25. $row = $dsql->GetOne("Select goodpost,badpost,scores From `$maintable` where id='$id' ");   
  26. if(!is_array($row))   
  27. {   
  28.     exit();   
  29. }   
  30. if($row['goodpost']+$row['badpost'] == 0)   
  31. {   
  32.     $row['goodper'] = $row['badper'] = 0;   
  33. }   
  34. else  
  35. {   
  36.     $row['goodper'] = number_format($row['goodpost']/($row['goodpost']+$row['badpost']),3)*100;   
  37.     $row['badper'] = 100-$row['goodper'];   
  38. }   
  39.   if(emptyempty($formurl)) $formurl = '';   
  40. if($formurl=='caicai')   
  41. {   
  42.     if($action == 'good') $digg = $row['goodpost'];   
  43.     if($action == 'bad') $digg  = $row['badpost'];   
  44. }   
  45. else  
  46. {   
  47.     $row['goodper'] = trim(sprintf("%4.2f", $row['goodper']));   
  48.     $row['badper'] = trim(sprintf("%4.2f", $row['badper']));      
  49.     $digg = '操作区:<a href="javascript:" onclick="javascript:postDigg(\'good\','.$id.')">顶</a>('.$row['goodpost'].') <a href="javascript:" onclick="javascript:postDigg(\'bad\','.$id.')">踩</a>('.$row['badpost'].')';   
  50. }   
  51. AjaxHead();   
  52. echo $digg;   
  53. exit();   
  54. ?>
复制代码

保存即可!
到此,我们的所有功能已经实现完毕。
2)效果演示
我们更新缓存、重新生成首页静态页面。查看的效果图如下:
1.webp
3)注意事项
本代码是基于织梦(织梦模板)已有的功能进行简易修改与运用后实现的,包括如下功能特点:
支持cookies记录,拒绝恶意点击(顶、踩)
支持arclist标签、List标签运用;
不影响系统其它功能的使用,升级方便;

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

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

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

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

关闭

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

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

GMT+8, 2024-11-24 01:25 , Processed in 0.045314 second(s), 7 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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