問題:
程式碼如下:
<code> //查找所有下级部门的id public static function actionSon($company_id,$id) { global $temp; $modelClass = self::find() ->where(['parent_id'=>$id,'company_id'=>$company_id]) ->all(); if(!empty($modelClass)){ foreach ($modelClass as $k => $value) { $temp[] =$value->id; self::actionSon($company_id,$value->id);//调用函数,传入参数,继续查询下级 } } return $temp; } </code>
<code>fields里面调用 public function fields() { return [ 'id', 'company_id' 'user_count'=>function(){ // return $this->getUserCount(); $dep_ids=self::actionSon($this->company_id,$this->id); // $GLOBALS['temp']=[]; //unset($temp); print_r($dep_ids); }, ]; }</code>
結果輸出:
得出重複的數據,如果列表還有部門的話會這樣一直重複下去,如何解決這個問題?
我需要的結果是每調用一次就能獲取到當前部門下的所有子部門的id,以一維數組的形式展示。
把$GLOBALS['temp']=[];放開它只能找到一級。
問題:
程式碼如下:
<code> //查找所有下级部门的id public static function actionSon($company_id,$id) { global $temp; $modelClass = self::find() ->where(['parent_id'=>$id,'company_id'=>$company_id]) ->all(); if(!empty($modelClass)){ foreach ($modelClass as $k => $value) { $temp[] =$value->id; self::actionSon($company_id,$value->id);//调用函数,传入参数,继续查询下级 } } return $temp; } </code>
<code>fields里面调用 public function fields() { return [ 'id', 'company_id' 'user_count'=>function(){ // return $this->getUserCount(); $dep_ids=self::actionSon($this->company_id,$this->id); // $GLOBALS['temp']=[]; //unset($temp); print_r($dep_ids); }, ]; }</code>
結果輸出:
得出重複的數據,如果列表還有部門的話會這樣一直重複下去,如何解決這個問題?
我需要的結果是每調用一次就能獲取到當前部門下的所有子部門的id,以一維數組的形式展示。
把$GLOBALS['temp']=[];放開它只能找到一級。