ECMS:论坛帖子调用
导航: 上一级 | 帝国CMS | 首页 | DedeCMS | Drupal | PHPCMS | PHP168 | Xoops | Joomla | PowerEasy | SupeSite
今天我们解密的是如何在帝国CMS中调用论坛贴子,从而实现论坛门户。
前言:
通常使用论坛的调用贴子JS即可调用论坛贴子,但今天我们要讲解的是如何用标签调用论坛贴子,因为标签更灵活。
原理说明:
通过ecmsinfo标签与按SQL调用相结合实现论坛数据调用。
使用要点:
- 采用ecmsinfo标签;(点击这里可以查看ecmsinfo标签使用教程)
标签语法:[ecmsinfo]栏目ID,显示条数,标题截取数,是否显示栏目名,操作类型,模板ID,只显示有标题图片[/ecmsinfo] - 标签中使用“按sql查询”操作类型;
标签参数中的“栏目ID”为SQL语句;“操作类型”为“24”。 - 制作显示样式模板
在标签模板中用“[!--title--]”贴子标题;“[!--id--]”表示贴子ID。
标签语法例子:(仅需设置红色部分)
[ecmsinfo]'select 贴子标题字段 as title,贴子ID字段 as id from 贴子数据表 order by 排序字段 desc limit 调用条数',0,标题截取字数,0,24,模板ID,0[/ecmsinfo]
例如:(调用论坛最新10个贴子)
Discuz论坛:[ecmsinfo]'select subject as title,tid as id from cdb_threads order by tid desc limit 10',0,30,0,24,1,0[/ecmsinfo]
PhpWind论坛:[ecmsinfo]'select subject as title,tid as id from pw_threads order by tid desc limit 10',0,30,0,24,1,0[/ecmsinfo]
(说明:如果论坛跟帝国CMS安装在不同的数据库,“贴子数据表”用“数据库.数据表”表示,如“discuzdb.cdb_threads”.)
·举例说明:调用DISCUZ论坛贴子
- 下图中是本地DISCUZ的版块与贴子。
图1:(版块列表)图2:(“默认论坛”版块贴子列表)
图3:(“论坛分类2”版块贴子列表)
图4:(“论坛分类1”版块贴子列表)
图5:(“论坛分类3”版块贴子列表)
- 调用DISCUZ论坛贴子标签语法:
[ecmsinfo]'select subject as title,tid as id from discuz5.cdb_threads order by tid desc limit 10',0,30,0,24,7,0[/ecmsinfo]
调用贴子数为10;贴子标题截取数为30个字;使用标签模板ID=7的模板。
(说明:其中“discuz5”为装discuz的数据库;“cdb5_”为数据表前缀。) - 制作显示样式模板:
登陆后台->"模板管理"->"增加标签模板",分别增加“显示一行一列”与“一行显示多列”两个标签模板。
图1:(一行一列标签模板)图2:(一行两列标签模板)
增加完成后,返回“标签模板”管理,会看到我们刚增加的两个标签,如下图:
- 现在我们修改首页模板:
登陆后台->"模板管理"->"公共模板"->"修改首页模板",将模板内容复制到DreamWeaver编辑,在模板中加入调用论坛贴子的标签,如下图:
(说明:其中“where fid=版块ID”为按论坛版块调用贴子。)
图1:(在dreamweaver中的首页模板)修改完首页模板后,将模板代码内容复制到后台首页模板文本框,然后点击修改,如下图:
修改首页模板后,我们点击“预览”,可以查看修改后的首页效果,如下图:
注意事项:4.6版本标签支持SQL语句是默认开启的,如果从4.0升级到4.6,要检查一下e/class/config.php是否设置开启标签支持SQL语句调用。
其它说明:上面举例的SQL语句是调用论坛及版块新贴,你还可以调用热门贴子、精华贴等等,只需改SQL语句的排序与条件即可。 还有更多应用,比如在信息页面中调用相关论坛贴子、调用其它系统数据等等。