青岛做网站
        行业新闻
行业新闻
当前位置:首页> 新闻动态 > 行业新闻

如何解决织梦选择多个副栏目只能保存一个的问题

更新时间:2017-01-18
   最新版的织梦程序有一定的bug,比如我们在发布文章时如果同时选择多个副栏目,保存后只能保存一个;再比如{dede:list}标签不支持weight权重排序。今天青岛做网站就跟大家分享一下这两个问题的解决方法,希望对大家有所帮助。

第一、如何解决织梦选择多个副栏目只能保存一个的问题

   我们在有织梦DEDE添加新文章的副栏目选择多个副栏目,保存后只剩下一个副栏目ID。比如我在副栏目部分选择23,24,253ID作为副栏目,保存文章后只剩下23,其他的2425都不见了,而更改文章,再添加上去的ID则可以保存。

   其实,这个是因为程序把$typeid2的数值整数化了,所以第一次添加文章的时候只剩下一个整数(栏目)。

修改回来的方法:

打开/include/helpers/archive.helper.php 这个文件,156行,这一段代码

$typeid2 = intval($typeid2);

改为 //$typeid2 = intval($typeid2);

或者删除

第二、如何让织梦DedeCMS{dede:list}标签支持weight权重排序

   其实如果想实现让织梦DedeCMS{dede:list}标签支持weight权重排序,其实很简单,修改几处代码即可,下面就讲一下这个功能是如何实现的。

1、找到"根目录\include\arc.listview.class.php"文件。

2、修改代码:在文件第727行处添加按weight排序判断代码(红色部分为新添加代码)

 //排序方式

$ordersql = ’’;

        if($orderby=="senddate" || $orderby=="id") {

            $ordersql=" ORDER BY arc.id $orderWay";

        }

        else if($orderby=="hot" || $orderby=="click") {

            $ordersql = " ORDER BY arc.click $orderWay";

        }

        else if($orderby=="lastpost") {

            $ordersql = "  ORDER BY arc.lastpost $orderWay";

        }

       else if($orderby=="weight") {

            $ordersql = "  ORDER BY arc.weight $orderWay";

        }

        else {

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

        }

3、再在第778行处找到此段代码

  //如果不用默认的sortrankid排序,使用联合查询(数据量大时非常缓慢)

     if(preg_match(’/hot|click|lastpost|weight/’, $orderby))

  并添加红色部分内容。

4、标签调用:

  {dede:list orderby=’weight’ orderway=’asc’}

  这样{dede:list}标签就支持了按权重排序的调用,并且动静态状态下测试均成功!

 

 

免责声明:本站所有资讯内容搜集整理于互联网或者网友提供,并不代表本网赞同其观点,仅供学习与交流使用,如果不小心侵犯到你的权益,如果你对文章内容、图片和版权等问题存在异议,请及时联系我们删除该信息。