dedecms 权重排序

介绍织梦dedecms的dede:list和dede:arclist列表按权重排序修改方法。调用方法:orderby=’weight’ orderway=’desc’ //desc和asc
有时候客户需要某几篇文章按照自己的意思排列顺序,就要用到按权重排序,下面介绍织梦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==lastpostelseif( orderby=="weight") { ordersql="orderbyarc.weight orderWay”; }
3,同样是这个文件,
查找“if(ereg(‘hot|click|lastpost’, orderby))if(ereg(hot|click|weight|lastpost, orderby))
上面三个步骤,即可实现列表页内容按权重排序,越小越靠前。dedecms v5.7SP1 测试成功!
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 == 'rand') $ordersql = "  ORDER BY rand()";

else if($orderby == 'weight') $ordersql = "  order by arc.weight $orderWay";   //主要是这一句,应该是这一句就够了,需要修改的小伙伴,试一下只改这里,上面绿色文字不改看看是不是也可以的

else $ordersql = " ORDER BY arc.sortrank $orderWay";

调用方法:orderby=’weight’ orderway=’desc’ //desc和asc

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值