DEDECMS给list标签加上多字段排序功能

百句空言,不如一个行动。凡事回归原点,不懂就不懂,努力学习;懂了也要相信人外有人,放下架子,谦虚,能力提升方可最大化!

dedecms的list标签orderby属性只支持按一个字段排序,假如想多个字段排序的话,就需要对PHP举办修改,使其可以支持多字段排序,修改如下:

打开include/arc.listview.class.php,找到:

//假如不消默认的sortrank或id排序,利用连系查询(数据量大时很是迟钝) 
       if(preg_match('/hot|click|lastpost|title/', $orderby)) 
       { 
           $query = "SELECT arc.*,tp.typedir,tp.typename,tp.isdefault,tp.defaultname, 
          tp.namerule,tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath 
          $addField
          FROM `js_archives` arc 
          LEFT JOIN `js_arctype` tp ON arc.typeid=tp.id 
          $addJoin
          WHERE {$this->addSql} $ordersql LIMIT $limitstart,$row"; 
       } 
       //普通环境先从arctiny表查出ID,然后按ID查询(速度很是快) 
       else
       { 
           $t1 = ExecTime(); 
           $ids = array(); 
           $query = "SELECT id FROM `js_arctiny` arc WHERE {$this->addSql} $ordersql LIMIT $limitstart,$row "; 
           $this->dsql->SetQuery($query); 
           $this->dsql->Execute(); 
           while($arr=$this->dsql->GetArray()) 
           { 
               $ids[] = $arr['id']; 
           } 
           $idstr = join(',',$ids); 
           if($idstr=='') 
           { 
               return ''; 
           } 
           else
           { 
               $query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname, 
                      tp.namerule,tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath 
                      $addField
                      FROM `js_archives` arc LEFT JOIN `js_arctype` tp ON arc.typeid=tp.id 
                      $addJoin
                      WHERE arc.id in($idstr) $ordersql "; 
           } 
           $t2 = ExecTime(); 
           //echo $t2-$t1; 
  
       }

替换为:

if($orderby=="default") 
       { 
           $t1 = ExecTime(); 
           $ids = array(); 
           $query = "SELECT id FROM `js_arctiny` arc WHERE {$this->addSql} $ordersql LIMIT $limitstart,$row "; 
           $this->dsql->SetQuery($query); 
           $this->dsql->Execute(); 
           while($arr=$this->dsql->GetArray()) 
           { 
               $ids[] = $arr['id']; 
           } 
           $idstr = join(',',$ids); 
           if($idstr=='') 
           { 
               return ''; 
           } 
           else
           { 
               $query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname, 
                      tp.namerule,tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath 
                      $addField
                      FROM `js_archives` arc LEFT JOIN `js_arctype` tp ON arc.typeid=tp.id 
                      $addJoin
                      WHERE arc.id in($idstr) $ordersql "; 
           } 
           $t2 = ExecTime(); 
           //echo $t2-$t1; 
  
       } 
        else
       { 
           $query = "SELECT arc.*,tp.typedir,tp.typename,tp.isdefault,tp.defaultname, 
          tp.namerule,tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath 
          $addField
          FROM `js_archives` arc 
          LEFT JOIN `js_arctype` tp ON arc.typeid=tp.id 
          $addJoin
          WHERE {$this->addSql} $ordersql LIMIT $limitstart,$row"; 
       }

找到:

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

替换为:

else if($orderby=="default"){ 
            $ordersql=" ORDER BY arc.sortrank $orderWay"; 
        } 
        else{ 
           $ordersql=" ORDER BY ".$orderby.",arc.sortrank $orderWay"; 
        }

此刻在模板中就可以应用了多字段排序了,模板应用如下:

{dede:list pagesize='17' orderby='arc.title desc,arc.id'}


以上就是DEDECMS给list标签加上多字段排序功能。生活,就是一首歌谣,用舒缓的旋律,低吟忧伤与温馨,生活,就是一首诗词,用精彩的文字,谱写快乐与悲伤,生活,就是零星琐碎生活,就是点滴温暖,生活,就是有一些小悲伤,人生,也会有许多小幸福。更多关于DEDECMS给list标签加上多字段排序功能请关注haodaima.com其它相关文章!

您可能有感兴趣的文章
dedecms如何实现任意页面调用当前会员信息的方

DedeCMS织梦判断是否有二级栏目输出HTML代码

织梦dedecms dede:arclist输出取消换行符

dedecms文章添加字段填栏目id,内容页调用字段里的栏目文章

dedeCMS首页列表页文章页调用tag的方法