php 递归实现无限级分类

//pid  父级id  result数据存储数组  spac子级前缀数量
function getlist($pid=0,&$result=array(),$spac=0)
{
    //调用数据库连接方法
    $db = SingleCase::getInstance();
    $spac += 2;
    $sql = "SELECT * FROM recursion WHERE Pid = $pid";
    $res = $db->query($sql)->fetchAll(PDO::FETCH_ASSOC);
    foreach ($res as $key => $value) {
        $value['catename'] = str_repeat(' ',$spac)."|--".$value['catename'];
        $result[] = $value;
        getlist($value['id'],$result,$spac);
    }
    return $result;
}

function displayCate($showid)
{
    $data = getlist();
    $str .= "<select name='cate'>";
    foreach ($data as $key => $value) {
        $selected = '';
        if ($value['id'] == $showid) {
            $selected = "selected";
        }
        $str .= "<option {$selected}>{$value['catename']}</option>";
    }
    return $str .= "</select>";
}

$showid = $_GET['pid'];
echo displayCate($showid);

结果示例图片


//cid 上一级主id     result返回数据的数组
function getCateLink($cid,&$result=array())
{
    $db = SingleCase::getInstance();
    $sql = "SELECT * FROM recursion WHERE id = $cid";
    $data = $db->query($sql)->fetchAll(PDO::FETCH_ASSOC);
    foreach ($data as $key => $value) {
        $result[] = $value;
        getCateLink($value['pid'],$result);
    }
    krsort($result);
    return $result;
}

function displayLink($cid)
{
    $data = getCateLink($cid);
    foreach ($data as $key => $value) {
        echo "<a href='recursion.php?pid={$value['id']}'>{$value['catename']}</a> >";
    }
}

displayLink(10);

结果示例图片

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值