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

1688源码 | 2018-04-16 23:02:16 |

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

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

   我们在有织梦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}标签就支持了按权重排序的调用,并且动静态状态下测试均成功!

精品源码
  • 织梦万能API 百度小程序插件

    惊爆价¥400原价¥800

    立即购买
  • 我爱登报网 百度小程序源码 织梦CMS后台

    惊爆价¥520原价¥1040

    立即购买
  • 索娜根布黑枸杞 百度小程序源码 织梦CMS后台

    惊爆价¥520原价¥1040

    立即购买
视觉焦点

推荐文章

帝国CMS简洁信息提示页模板源码

帝国CMS 灵动标签调用所有tags代码

DEDECMS织梦后台自定义表单添加搜索功能

帝国CMS7.5 列表页获取图集图片数量代码

最新文章

关注我们

微信扫一扫,关注更多精彩

  • 1688源码公众号
    全面掌握源码一手资讯

  • 1688源码公众号
    精彩活动,推送提醒