程序员人生 网站导航

解决DedeCMS网站专题排序问题

栏目:DedeCMS时间:2013-11-18 11:21:11

刚弄一个专题,添加内容发现内容标题不是按照添加的id排序的,也不是按照id顺序排列的。感觉像是随机的。这样不是我想要得效果,所以查询了百度半天,dedecms论坛半天发现没有解决的方法。所以我就开始研究php文件,我觉得肯定有sql查询文件。注意orderby 即可。可是文件再哪个地方呢?我找了半天。终于解决。现在将我的方法介绍给大家。

按照 标题的id 降序排列。

这个效果需要修改2 个php文件。

第一步骤:
1. 修改 include aglibchannelspecialtopic.lib.php 文件

2. 在第52行 处 有这行代码:

$ctag->GetAtt('imgwidth'), $ctag->GetAtt('imgheight'), 'all', 'default', $keywords, $listTemplet, 0, $idlist,
修改成:
$ctag->GetAtt('imgwidth'), $ctag->GetAtt('imgheight'), 'all', 'asc', $keywords, $listTemplet, 0, $idlist,
3. 保存文件结束

第二步骤:
1.修改include aglibarclist.lib.php

2. 大约在196行处。有这行代码:

//文档排序的方式
$ordersql = '';
if($orderby=='hot' || $orderby=='click') $ordersql = " order by arc.click $orderWay";
else if($orderby == 'sortrank' || $orderby=='pubdate') $ordersql = " order by arc.sortrank $orderWay";
else if($orderby == 'id') $ordersql = " order by arc.id $orderWay";
else if($orderby == 'near') $ordersql = " order by ABS(arc.id - ".$arcid.")";
else if($orderby == 'lastpost') $ordersql = " order by arc.lastpost $orderWay";
else if($orderby == 'scores') $ordersql = " order by arc.scores $orderWay";
else if($orderby == 'rand') $ordersql = " order by rand()";
/*** 在这下面添加 ***/
else if($orderby == 'asc') $ordersql = " order by arc.id asc";
/*** 添加结束 ***/
else $ordersql = " order by arc.sortrank $orderWay";
3. 修改结束

好了。刷新文件看看吧(注意不是html,是动态页面。或者重新生成下专题html 看看效果吧)

------分隔线----------------------------
------分隔线----------------------------

最新技术推荐