怎么让织梦文章按照权重排序

如题所述

有时候客户需要某几篇文章按照自己的意思排列顺序,就要用到按权重排序,下面秀站网介绍织梦dedecms的dede:list和dede:arclist列表按权重排序修改方法。
倒序 orderway='asc'
orderway是设置排序的方式,值为desc和asc
dedecms列表页实现文档按权重weight排序
1,在list_artcile.htm模板中使用
{dede:list pagesize='12′ orderby='weight' orderway='desc'}
2,然后修改include目录下的arc.listview.class.php
查找else if($orderby=="lastpost") { $ordersql = " ORDER BY arc.lastpost $orderWay";} , dedecms5.7sp2大概在768行
在下面补充
else if($orderby=="weight") { $ordersql = " order by arc.weight $orderWay"; }
3,同样是这个文件,
查找“if(preg_match('/hot|click|lastpost/', $orderby))”
改为:
if(preg_match('/hot|click|weight|lastpost/', $orderby))
上面三个步骤,即可实现列表页内容按权重排序,越小越靠前。仅限dedecms v5.7 SP2测试!
dede:arclist按权重排序的修改方法
1、在织梦系统中找到以下目录\include\taglib中的arclist.lib.php文件并打开
大约在74 、75行找到:
// arclist是否需要weight排序,默认为"N",如果需要排序则设置为"Y"
$isweight = $ctag->GetAtt('isweight');
把这行修改为:
$weight = $ctag->GetAtt('weight');
或者修改了 170行 $isweight='N' 的值为Y
大约在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 == 'weight') $ordersql = " order by arc.weight $orderWay"; //主要是这一句,应该是这一句就够了,需要修改的小伙伴,试一下只改这里,上面绿色文字不改看看是不是也可以的
调用方法:orderby='weight' orderway='desc' //desc和asc
本文地址:http://www.xiuzhanwang.com/dedecms_jq/779.html
温馨提示:内容为网友见解,仅供参考
第1个回答  2019-06-24
你好,你问题中所说的“权重”百度权重吗?如果是百度权重,那这个就没有办法,因为百度权重只是大家提出的一个虚拟数值,是来衡量网站重要性的,百度不会纰漏准确的数值。
***织梦文章排序,有6种方式***
1、按照权重排序(你说的权重,应该是指这个):
1orderby='weight'
最后的效果如下:
123456789101112{dede:arclist row='14' titlelen='48' orderby='weight' typeid='9' idlist=''} <li> <span class="title f_l"> <a href="[field:filename/]" title="[field:title/]"> [field:array runphp='yes'] if (@me['shorttitle']=='') @me=@me['title'];else @me=@me['shorttitle'];[/field:array] </a> </span> <span class="pubdate f_r"> [field:pubdate function=MyDate('Y-m-d',@me)/] </span> </li>{/dede:arclist}
2、按照更新时间排序,则在标签中加入以下代码:
1orderby='sortrank' 或 orderby='pubdate'
3、按照用户点击数量排序,则在标签中加入以下代码:
1orderby='hot' 或 orderby='click'
4、按照文章最后的评论时间排序,则在标签中加入以下代码:
1orderby=='lastpost'
5、按照得分排序:
1orderby=='scores'
6、按照文章的id进行排序:
1orderby='id'
在赵一鸣随笔博客中有《dedecms织梦建站视频教程完整版》免费观看,你可以作为参考。
如果我的回答对你有用,可以采纳哦!
相似回答