Discuz!官方免费开源建站系统

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索

X2 帖子列表页新回复帖自动提示机制分析

[复制链接]
云天一 发表于 2011-4-1 15:58:35 | 显示全部楼层 |阅读模式
本帖最后由 云天一 于 2011-4-1 16:29 编辑

*************************************************
** 本教程基于版本:Discuz! X 2.0                                         **
*************************************************
x2 新添加了一个功能当用户查看一个版块帖子列表页,短时间内没有刷新操作,如果有其它用户在相同版块发帖时,一定时间后,查看该版未作刷新操作的用户的帖子列表页会一条有新回复主题的帖的提醒


具体实现我们可以了解一下如下:

当用户查看一个版块帖时,程序模板 ./template/default/forum/forumdisplay.htm
此文件在版块为非图片版模式 (empty($_G['forum']['picstyle']) ) 并且为按默认的最新回复排序看帖 ($_G['gp_orderby'] == 'lastpost')时,会在版块的帖子列表页底部加一段 js 代码
  1. <script type="text/javascript">checkForumnew_handle = setTimeout(function () {checkForumnew($_G[fid], lasttime);}, checkForumtimeout);</script>
复制代码
该 js 会使用 setTimeout 函数 根据 forum.js 里面设定的 checkForumtimeout 的值(程序默认为30000 即30秒)执行 checkForumnew() 函数,如下
  1. function checkForumnew(fid, lasttime) {
  2.         var timeout = checkForumtimeout;
  3.         var x = new Ajax();
  4.         x.get('forum.php?mod=ajax&action=forumchecknew&fid=' + fid + '&time=' + lasttime + '&inajax=yes', function(s){
  5.                 if(s > 0) {
  6.                         if($('separatorline')) {
  7.                                 var table = $('separatorline').parentNode;
  8.                         } else {
  9.                                 var table = $('forum_' + fid);
  10.                         }
  11.                         if(!isUndefined(checkForumnew_handle)) {
  12.                                 clearTimeout(checkForumnew_handle);
  13.                         }
  14.                         removetbodyrow(table, 'forumnewshow');
  15.                         var colspan = table.getElementsByTagName('tbody')[0].rows[0].children.length;
  16.                         var checknew = {'tid':'', 'thread':{'common':{'className':'', 'val':'<a href="javascript:void(0);" onclick="ajaxget(\'forum.php?mod=ajax&action=forumchecknew&fid=' + fid+ '&time='+lasttime+'&uncheck=1&inajax=yes\', \'forumnew\');">有新回复的主题,点击查看', 'colspan': colspan }}};
  17.                         addtbodyrow(table, ['tbody'], ['forumnewshow'], 'separatorline', checknew);
  18.                 } else {
  19.                         if(checkForumcount < 50) {
  20.                                 if(checkForumcount > 0) {
  21.                                         var multiple =  Math.ceil(50 / checkForumcount);
  22.                                         if(multiple < 5) {
  23.                                                 timeout = checkForumtimeout * (5 - multiple + 1);
  24.                                         }
  25.                                 }
  26.                                 checkForumnew_handle = setTimeout(function () {checkForumnew(fid, lasttime);}, timeout);
  27.                         }
  28.                 }
  29.                 checkForumcount++;
  30.         });

  31. }
复制代码
forum.js 中的 checkForumnew() 会 实例一个 Ajax对象
通过ajax 请求 forum.php?mod=ajax&action=forumchecknew&fid=' + fid + '&time=' + lasttime + '&inajax=yes

通过地址很容易看到请求的 ./source/module/forum/forum_ajax.php
该文件根据传过来版块fid的值 从 forum_forum 表查出该版块记录有最新回复的主题帖的 lastpost 的字段的值并不是从 forum_post 表查的最新帖
然后判断 ajax 所请求的时间是否大于 此字段记录中所记录的最新帖子的时间 来返回是否存在最新帖
如果请求的时间小于最新帖时间 那表示有最新帖 则返回 1 否则返回 0

返回是否有新帖被传成 forum.js 中的 checkForumnew()  中 function(s) s值  
通过判断 s 值

如果 s 值为0 没有最新帖 forum.js 会根据一定算法把 慢慢延长 ajax 请求查询是否有新帖的周期 以防止过去频繁的查询

如果  s 值为1 有最新帖
forum.js 判断了checkForumnew_handle 来清除 setTimeout() 方法设置的 timeout 的值,以防止用户未点击查看新帖提示之前程序做重复的查询浪费资源,并且使用自定义函数 addtbodyrow 添加新帖提醒节点及获取新帖的ajax
  1. onclick="ajaxget(\'forum.php?mod=ajax&action=forumchecknew&fid=' + fid+ '&time='+lasttime+'&uncheck=1&inajax=yes\', \'forumnew\');"
复制代码
此时用户就会在帖子列表页看到上面图中所提示的现状 “有新回复的主题,点击查看”。

当用户点击 “有新回复的主题,点击查看”时, 程序会以ajax 请求 forum.php?mod=ajax&action=forumchecknew&fid=' + fid+ '&time='+lasttime+'&uncheck=1&inajax=yes  地址

同样 通过地址很容易看到请求 ./source/module/forum/forum_ajax.php 文件, 而地址多了一个 uncheck 参数,
根据uncheck进入查询具体新主题的判断,程序从 forum_thread 根据当前 ajax 请求的时间,查出最新的帖子返回,此时
  1. include template('forum/ajax_threadlist');
复制代码
包含一个  ./template/default/forum/ajax_threadlist.htm 模板文件 将最新回复的帖子标题等内容 输出展示在帖子列表







本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

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

本版积分规则

手机版|小黑屋|Discuz! 官方站 ( 皖ICP备16010102号 )star

GMT+8, 2024-6-17 00:25 , Processed in 0.118312 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2023, Tencent Cloud.

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