DEDE 首页 列表页 按照权重排序的解析方法

实习编辑 2020年6月12日13:35:00其他DEDE 首页 列表页 按照权重排序的解析方法已关闭评论67阅读模式

【免责声明】

  1、本网站部分文章信息来源于网络转载是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如其他媒体、网站或个人从本网下载使用,必须保留本网注明的“稿件来源”,并自负版权等法律责任。如对稿件内容有疑议,请及时与我们联系。

  2、本网站致力于提供合理、准确、完整的资讯信息,但不保证信息的合理性、准确性和完整性,且不对因信息的不合理、不准确或遗漏导致的任何损失或损害承担责任。本网站所有信息仅供参考,不做交易和服务的根据, 如自行使用本网资料发生偏差,本站概不负责,亦不负任何法律责任。

  3、任何由于黑客攻击、计算机病毒侵入或发作、因政府管制而造成的暂时性关闭等影响网络正常经营的不可抗力而造成的损失,本网站均得免责。由于与本网站链接的其它网站所造成之个人资料泄露及由此而导致的任何法律争议和后果,本网站均得免责。

  4、本网站如因系统维护或升级而需暂停服务时,将事先公告。若因线路及非本公司控制范围外的硬件故障或其它不可抗力而导致暂停服务,于暂停服务期间造成的一切不便与损失,本网站不负任何责任。

  5、本网站使用者因为违反本声明的规定而触犯中华人民共和国法律的,一切后果自己负责,本网站不承担任何责任。

  6、凡以任何方式登陆本网站或直接、间接使用本网站资料者,视为自愿接受本网站声明的约束。

  7、本声明未涉及的问题参见国家有关法律法规,当本声明与国家法律法规冲突时,以国家法律法规为准。

  8、本网站如无意中侵犯了哪个媒体或个人的知识产权,请联系我们QQ:316865155,本网站将立即给予删除。

dede列表页权重排序:
根据权重排序dede_arctiny 按weight实现文档按权重weight排序(从小到大的顺序)方法:
1,在list_artcile.htm模板中使用
{dede:list pagesize=’12′ orderby=’weight’ orderway=’asc’}
2,然后修改include目录下的arc.listview.class.php
查找else if($orderby==”lastpost。。。
在下面补充
else if($orderby==”weight”) { $ordersql = ” order by arc.weight $orderWay”; }
3,同样是这个文件,查找“if(ereg(‘hot|click|lastpost’,$orderby))”改为:
if(ereg(‘hot|click|weight|lastpost’,$orderby))

上面三个步骤,即可实现列表页内容按权重排序,越小越靠前。

希望以上内容对大家有所帮助。

首页按照权重排序:

1、在织梦系统中找到以下目录includetaglib中的arclist.lib.php文件并打开

   大约在74 、75行找到:

      // arclist是否需要weight排序,默认为"N",如果需要排序则设置为"Y"
    $isweight = $ctag->GetAtt('isweight');

把这行修改为:

  $weight = $ctag->GetAtt('weight');

大约在327行找到

    //文档排序的方式
    $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 $ordersql = " ORDER BY arc.sortrank $orderWay";

修改为:

    //文档排序的方式
    $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 == 'weight') $ordersql = "  order by arc.weight asc";//如果没有特定设置排序则按照权重先排序
    else $ordersql = " ORDER BY arc.sortrank $orderWay";

OK   现在把这个文档保存了  我们就可以在首页使用 orderby='weight' 进行排序了。

备注:按照大还是小排序,如下修改:

织梦dedecms有一个按权重排序功能,不过是按权重越小越靠前来排序的。由于文章它默认权重跟ID相同,是越来越大的,所以有很多文章时,我们按照越小越靠前是很不合理的,所以我们要把它权重改成越大越靠前。

   方法:
    1. 在includetaglibarclist.lib.php文件中,将    else if($orderby == 'weight') $ordersql = "  order by arc.weight asc";//如果没有特定设置排序则按照权重先排序

    2.改成   else if($orderby == 'weight') $ordersql = "  order by arc.weight desc";//如果没有特定设置排序则按权重越大越靠前排序


 

 

  • 18922299980
  • 扫一扫加我微信
  • weinxin
  • 公众号:名将VR全景
  • 扫一扫在微信上关注我们
  • weinxin
实习编辑
  • 本文由 发表于 2020年6月12日13:35:00
  • 转载请务必保留本文链接:http://blog.hzzx3d.com/6541.html