用织梦建站时候我们遇到某几篇文章按照自己的意思排列顺序,就要用到按权重排序,下面介绍织梦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
总结
以上是内存溢出为你收集整理的织梦列表页排序按权重排序修改方法全部内容,希望文章能够帮你解决织梦列表页排序按权重排序修改方法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)