全网整合营销服务商

电脑端+手机端+微信端+aoa体育官网SEO优化=数据同步管理

免费咨询热线:13962806263

  • 首页
  • 微信开发
  • 手机商城
  • 小程序
  • 营销型aoa体育官网
  • 响应式aoa体育官网
  • 解决方案
  • 案例展示
  • 关于我们
  • 新闻资讯
  • 织梦列表页实现按权重排序的方法

    发布时间:2020-03-18 15:42  作者:安讯信息  点击数:
    织梦后台添加文章的时候,有个权重的选项,数值越小越靠前,但是修改后发现没有用,那是怎么回事呢?原来需要修改两个文件就可以了。

    倒序 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
    tags:织梦, 权重

    您的项目需求

    *请认真填写需求信息,我们会在24小时内与您取得联系。

  • 返回顶部
  • 0513-81185251
  • QQ在线
  • 微信二维码
    关注安讯信息