dede 5.7 二级联动三级联动添加异常bug完美修复

二级联动添加bug网上找了很多资料。修复后要么二级能添加三级却不能添加了。逼不得已研究了下终于解决了。算是123级添加bug完美修复吧

首先

1.dede/stepselect_main.php 文件

 

以下替换源文件215行的对应代码

 

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 `#@__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 `#@__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 == 3 && $topvalue != 0)
    {
        $minid = $topvalue;
        $maxnum = 500; // 三级子类最多500个
        $enames = explode(',', $ename);
        foreach ($enames as $ename)
        {
            $arr = $dsql->GetOne("SELECT * FROM `#@__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("%03d", $addvalue);
                $evalue = $matchs[1].'.'.$addvalue;
            }
            $sql = "INSERT INTO `#@__sys_enum`(`ename`,`evalue`,`egroup`,`disorder`,`issign`) 
                                    VALUES('$ename','$evalue','$egroup','$disorder','$issign'); ";
            // echo $sql;exit;
            $dsql->ExecuteNoneQuery($sql); 
        }
        // echo $minid;
        WriteEnumsCache($egroup);
        ShowMsg("成功添加枚举分类!".$issign, $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 = (int)($arr['evalue']+1);
    }
    $dsql->ExecuteNoneQuery("Insert into `dede_sys_enum`(`ename`,`evalue`,`egroup`,`disorder`,`issign`)
                                 values('$ename','$evalue','$egroup','$disorder','$issign'); ");
       }
       WriteEnumsCache($egroup);
   ShowMsg("成功添加枚举分类!".$issign, $ENV_GOBACK_URL);
   exit();
 }
}


 2.dede/templets/stepselect_main.htm

找到

if($topvalue % 500 != 0) $arr['issign'] = 2;

修改为

if($topvalue % 500 != 0) $arr['issign'] = 3;

 if($topvalue % 500 == 0) $arr['issign'] = 2;

 以上这样修改后1,2,3 联动能添加,再4级就不行了。应为这里的标记只判断到3,织梦也最多能添加3级联动。所以足够用了。


复制的时候代码里会出现问题。比如

if(empty($ename) || empty($egroup)) 
 这一块。不知道csdn 代码功能出错还是什么原因,就 多了empty单词


 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值