第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機(jī)立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

php無限極分類深度如何控制

php無限極分類深度如何控制

PHP
aluckdog 2022-11-04 16:30:14
這是我的數(shù)組: $list = array(        array('id' => 3, 'name' => 'Phones', 'parent_id' => 0,),        array('id' => 256, 'name' => 'Accessories', 'parent_id' => 0,),        array('id' => 308, 'name' => 'Appliances', 'parent_id' => 0,),        array('id' => 1057, 'name' => 'Smart', 'parent_id' => 0,),        array('id' => 1065, 'name' => 'Smart Phones', 'parent_id' => 3,),        array('id' => 1066, 'name' => 'Feature Phones', 'parent_id' => 3,),        array('id' => 1069, 'name' => 'Samsung', 'parent_id' => 1065,),        array('id' => 1070, 'name' => 'Apple', 'parent_id' => 1065,),        array('id' => 1072, 'name' => 'Apple', 'parent_id' => 1066,),        array('id' => 1075, 'name' => 'Tablets', 'parent_id' => 0,),        array('id' => 1076, 'name' => 'Samsung', 'parent_id' => 1066,),        array('id' => 1077, 'name' => 'All Brands', 'parent_id' => 1075,),        array('id' => 1078, 'name' => 'Samsung', 'parent_id' => 1077,),        array('id' => 1079, 'name' => 'Protector', 'parent_id' => 256,),        array('id' => 1080, 'name' => 'Power', 'parent_id' => 256,),        array('id' => 1081, 'name' => 'Cable', 'parent_id' => 256,),        array('id' => 1082, 'name' => 'Memory', 'parent_id' => 256,),    );這是我分類的代碼:function  quote_make_tree($list,$deep=1, $root = 0){    $tree = $packData = [];    foreach ($list as $row) {        $packData[$row['id']] = $row;    }    foreach ($packData as $key => $val) {        if ($val['parent_id'] == $root) {            $tree[] = &$packData[$key];        } else {            $packData[$val['parent_id']]['children'][] = &$packData[$key];        }    }    return $tree;}我想添加一個深度參數(shù)$deep來quote_make_tree控制分類的深度。if $deep = 2,獲取level 1分類下的level 2分類,if $deep=3,獲取所有1,2,3分類我已經(jīng)嘗試先獲取所有數(shù)據(jù),然后根據(jù)$deep.here is demo刪除數(shù)據(jù),謝謝大家
查看完整描述

1 回答

?
守候你守候我

TA貢獻(xiàn)1802條經(jīng)驗(yàn) 獲得超10個贊

使用遞歸方法可能更容易解決。這使您可以檢查深度,如果您想要更多細(xì)節(jié),那么它將調(diào)用自己添加更多層。每次稱自己時,您只需從深度中刪除一個...


function  quote_make_tree($list, $deep=1, $root = 0) {

    $output = [];

    foreach ( $list as $listItem )  {

        if ( $listItem['parent_id'] == $root ) {

            if ( $deep > 1 )    {

                $listItem['children'] = quote_make_tree($list, $deep-1, $listItem['id']);

            }

            $output[] = $listItem;

        }

    }

    return $output;

}


查看完整回答
反對 回復(fù) 2022-11-04
  • 1 回答
  • 0 關(guān)注
  • 139 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號