找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1313|回复: 0

[分享] dede专题节点文章按id,点击等类型排序

[复制链接]
发表于 2018-3-10 08:18:36 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
点评:使用dedecms弄一个专题,添加内容发现内容标题不是按照添加的id排序的,也不是按照id顺序排列的。感觉像是随机的
   
按照 标题的id  降序排列。
这个效果需要修改2 个php文件。
第一步骤:
1. 修改  includetaglibchannelspecialtopic.lib.php  文件
2. 在第52行 处 有这行代码:
                       
  1. $ctag->GetAtt('imgwidth'), $ctag->GetAtt('imgheight'), 'all', 'default', $keywords, $listTemplet, 0, $idlist,
复制代码

修改成:
                       
  1. $ctag->GetAtt('imgwidth'), $ctag->GetAtt('imgheight'), 'all', 'asc', $keywords, $listTemplet, 0, $idlist,
复制代码

3. 保存文件结束
第二步骤:
1.修改includetaglibarclist.lib.php
2. 大约在196行处。有这行代码:
  1.    //文档排序的方式
  2.     $ordersql = '';
  3.     if($orderby=='hot' || $orderby=='click') $ordersql = " order by arc.click $orderWay";
  4.     else if($orderby == 'sortrank' || $orderby=='pubdate') $ordersql = " order by arc.sortrank $orderWay";
  5.     else if($orderby == 'id') $ordersql = "  order by arc.id $orderWay";
  6.     else if($orderby == 'near') $ordersql = " order by ABS(arc.id - ".$arcid.")";
  7.     else if($orderby == 'lastpost') $ordersql = "  order by arc.lastpost $orderWay";
  8.     else if($orderby == 'scores') $ordersql = "  order by arc.scores $orderWay";
  9.     else if($orderby == 'rand') $ordersql = "  order by rand()";
  10.     //增加  开始
  11.            else if($orderby == 'asc') $ordersql = "  order by arc.id asc";
  12.     //增加 结束
  13.     else $ordersql = " order by arc.sortrank $orderWay";
复制代码

3.  修改结束

下面再给一个实现方法

1、找到 include/taglib//channel/specialtopic.lib.php
2、将 require_once(DEDEINC.'/taglib/arclist.lib.php'); 换成 require_once(DEDEINC.'/taglib/arclist.lib2.php');
3、复制arclist.lib.php 改名成 arclist.lib2.php
然后修改arclist.lib2.php
查找$order='desc' 替换成
  1. $orderby='id'
复制代码


仿站关于是升序还是降序排列只需要
查找$orderWay = AttDef($order,'desc'); 替换成 $orderWay = AttDef($order,'asc');

想调用以下参数,只需要按着修改就行
§ orderby='hot' 或 orderby='click' 表示按点击数排列
§ orderby='sortrank' 或 orderby='pubdate' 按出版时间排列
§ orderby='near'
§ orderby=='lastpost' 按最后评论时间
§ orderby=='scores' 按得分排序
§ orderby='id' 按文章ID排序
§ orderby='rand' 随机获得指定条件的文档列表

对于dedecms 5.1的版本

id排序增加功能更
include/inc/.inc_fun_SpFullList.php

  1. //文档排序的方式
  2. $ordersql = "";
  3. if($orderby=='rand') $ordersql = " order by rand()";
  4. else if($orderby=='click'||$orderby=='hot') $ordersql = " order by arcf.click desc";
  5. else if($orderby=='digg') $ordersql = " order by arcf.digg desc";
  6. else if($orderby=='diggtime') $ordersql = " order by arcf.diggtime desc";
  7. else $ordersql=" order by arcf.aid desc";
  8. // 2013年针对专题id列表所加功能
  9. if($idlist!=''){
  10. $ordersql = " order by find_in_set(arcf.aid,'$idlist')";
  11. }
复制代码

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

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

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

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

关闭

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

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

GMT+8, 2024-11-22 17:38 , Processed in 0.049718 second(s), 9 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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