魔扣论坛

魔扣源码论坛业务
查看: 476|回复: 2

[织梦教程] 织梦5.7bug修复:后台联动不能添加二级栏目的解决方法

[复制链接]
  • TA的每日心情
    奋斗
    23 小时前
  • 签到天数: 2958 天

    [LV.Master]开坛老将

    7万

    主题

    227

    回帖

    27万

    积分

    管理员

    Rank: 30Rank: 30Rank: 30Rank: 30Rank: 30Rank: 30Rank: 30Rank: 30

    魔扣币
    745789
    贡献
    157917
    威望
    32799

    最佳新人活跃会员热心会员推广达人宣传达人突出贡献优秀版主荣誉管理论坛元老

    发表于 2020-6-30 23:38:43 | 显示全部楼层 |阅读模式
    魔扣币兑换比例:【 50以下 : ¥1 = 10 魔扣币 】丨【 50 - 100 :¥1 = 20 魔扣币】丨【 100以上:¥1 = 30 魔扣币 】

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?立即注册

    x
    我在使用的分类信息的时候需要添加联动属性,结果去添加联动属性的时候,发现只可以添加一级联动和三级联动。
    二级联动无法添加了。
    在自己的5.6的后台添加的时候,发现是可以的。估计又是5.7版本的bug了。

        于是分析了代码,和大家分享下解决的办法:
    首先我们找到我们的模板源码下面的 dede/stepselect_main.php  这个文件,

    将这段代码

    else if($action=='addenum_save')
    {
        if(empty($ename) || empty($egroup))
        {
             Showmsg("类别名称或组名称不能为空!","-1");
             exit();
        }
        if($issign == 1 || $topvalue == 0)
        {
            $enames = explode(',', $ename);
            foreach($enames as $ename)
            {
                $arr = $dsql->GetOne("SELECT * FROM `dede_sys_enum` WHERE egroup='$egroup' AND (evalue MOD 500)=0 ORDER BY disorder DESC ");
                if(!is_array($arr)) $disorder = $evalue = ($issign==1 ? 1 : 500);
                else $disorder = $evalue = $arr['disorder'] + ($issign==1 ? 1 : 500);

                $dsql->ExecuteNoneQuery("INSERT INTO `dede_sys_enum`(`ename`,`evalue`,`egroup`,`disorder`,`issign`)
                                        VALUES('$ename','$evalue','$egroup','$disorder','$issign'); ");
            }
            WriteEnumsCache($egroup);                                                         
            ShowMsg("成功添加枚举分类!".$dsql->GetError(), $ENV_GOBACK_URL);
            exit();
        } else if ($issign == 2 && $topvalue != 0)
        {
            $minid = $topvalue;
            $maxnum = 500; // 三级子类最多500个
            $enames = explode(',', $ename);
            foreach ($enames as $ename)
            {
                $arr = $dsql->GetOne("SELECT * FROM `dede_sys_enum` WHERE egroup='$egroup' AND evalue LIKE '$topvalue.%%%' ORDER BY evalue DESC ");
                if(!is_array($arr))
                {
                    $disorder = $minid;
                    $evalue = $minid.'.001';
                }
                else
                {
                    $disorder = $minid;
                    preg_match("#([0-9]{1,})\.([0-9]{1,})#", $arr['evalue'], $matchs);
                    $addvalue = $matchs[2] + 1;
                    $addvalue = sprintf("d", $addvalue);
                    $evalue = $matchs[1].'.'.$addvalue;

    }
                $sql = "INSERT INTO `dede_sys_enum`(`ename`,`evalue`,`egroup`,`disorder`,`issign`)
                                        VALUES('$ename','$evalue','$egroup','$disorder','$issign'); ";
                // echo $sql;exit;
                $dsql->ExecuteNoneQuery($sql);
            }
            // echo $minid;
            WriteEnumsCache($egroup);
            ShowMsg("成功添加枚举分类!", $ENV_GOBACK_URL);
            exit();
        } else {
            $minid = $topvalue;
            $maxid = $topvalue + 500;
            $enames = explode(',', $ename);
            foreach($enames as $ename)
            {
                $arr = $dsql->GetOne("SELECT * FROM `dede_sys_enum` WHERE egroup='$egroup' AND evalue>$minid AND evalue<$maxid ORDER BY evalue DESC ");
                if(!is_array($arr))
                {
                    $disorder = $evalue = $minid+1;
                }
                else
                {
                    $disorder = $arr['disorder']+1;
                    $evalue = $arr['evalue']+1;
                }
                $dsql->ExecuteNoneQuery("INSERT INTO `dede_sys_enum`(`ename`,`evalue`,`egroup`,`disorder`,`issign`)
                              VALUES('$ename','$evalue','$egroup','$disorder','$issign'); ");
            }
            WriteEnumsCache($egroup);
            ShowMsg("成功添加枚举分类!", $ENV_GOBACK_URL);
            exit();
        }
    }

    替换为:

    else if($action=='addenum_save')
    {
       if(empty($ename) || empty($egroup)) {
          Showmsg("类别名称或组名称不能为空!","-1");
          exit();
       }
       if($issign==1 || $topvalue==0)
       {
           $enames = explode(',', $ename);
           foreach($enames as $ename)
           {
            $arr = $dsql->GetOne("Select * From `dede_sys_enum` where egroup='$egroup' And (evalue mod 500)=0 order by evalue desc ");

         if(!is_array($arr)) $disorder = $evalue = ($issign==1 ? 1 : 500);
         else $disorder = $evalue = $arr['disorder'] + ($issign==1 ? 1 : 500);

         $dsql->ExecuteNoneQuery("Insert into `dede_sys_enum`(`ename`,`evalue`,`egroup`,`disorder`,`issign`)
                                        values('$ename','$evalue','$egroup','$disorder','$issign'); ");
            }
            WriteEnumsCache($egroup);     

    ShowMsg("成功添加枚举分类!".$dsql->GetError(), $ENV_GOBACK_URL);
        exit();
      }
      else
      {
        $minid = $topvalue;
        $maxid = $topvalue + 500;
        $enames = explode(',', $ename);
           foreach($enames as $ename)
           {
         $arr = $dsql->GetOne("Select * From `dede_sys_enum` where egroup='$egroup' And evalue>$minid And evalue<$maxid order by evalue desc ");
         if(!is_array($arr))
         {
          $disorder = $evalue = $minid+1;
         }
         else
         {
          $disorder = $arr['disorder']+1;
          $evalue = $arr['evalue']+1;
         }
         $dsql->ExecuteNoneQuery("Insert into `dede_sys_enum`(`ename`,`evalue`,`egroup`,`disorder`,`issign`)
                                      values('$ename','$evalue','$egroup','$disorder','$issign'); ");
            }
            WriteEnumsCache($egroup);
        ShowMsg("成功添加枚举分类!", $ENV_GOBACK_URL);
        exit();
      }
    }

    然后保存,在系统后台更新系统缓存就可以了的。现在在后台的联动类别管理里面就可以增加二级选择了。

    会员购买:>> 点击购买 << | 魔扣币购买:>> 点击购买 <<
    承接业务:服务器代维丨网站托管丨SEO
    联系客服:微信:morko-net | QQ:1367681973

    该用户从未签到

    3

    主题

    240

    回帖

    484

    积分

    中级魔扣

    Rank: 3Rank: 3

    魔扣币
    241
    贡献
    241
    威望
    0
    发表于 2020-7-1 09:00:15 | 显示全部楼层
    做你最好的朋友,将爱在心底悄悄地掩埋;晨浴甘露,夜伴晚霞,让友谊的花静静地绽开。做你最好的朋友,跳动的脉搏与你同在;清澈似水,纯真如玉,惟有深深的牵挂和关爱。魔扣源码论坛做你最好的朋友,无论过去、现在和将来!

    该用户从未签到

    2

    主题

    229

    回帖

    462

    积分

    中级魔扣

    Rank: 3Rank: 3

    魔扣币
    231
    贡献
    231
    威望
    0
    发表于 2020-8-22 11:10:22 | 显示全部楼层
    为了三千积分!
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    • 联系我们
    • 新浪微博 :
    • 在线客服 :魔扣科技 
    • 源码QQ群 :魔扣源码论坛官方总群
    • 联系邮箱 :charlin#morko.net
    • 微信扫一扫
    快速回复 返回顶部 返回列表