找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1332|回复: 0

[分享] dedecms首页中文章列表无刷新顶、踩的实现方法

[复制链接]
发表于 2018-2-26 14:00:47 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡–牧野区
dedecms的顶客如何实现文章被顶后首页实时刷,而不需要全站刷新?就像A5首页的那样。
经过简单的修改和测试已在本地运行环境中实现了该问题的效果,现将有关代码与解释贴出,希望能给大家一点参考:
第一步:首先创建一个空白首页文件,在里面<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.xuewl.com)
  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. ?>
复制代码

保存即可!

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

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

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

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

关闭

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

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

GMT+8, 2024-11-19 06:30 , Processed in 0.038784 second(s), 9 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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