时间:2021-07-01 10:21:17 帮助过:19人阅读
问题:
代码如下:
- <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']=[];放开它只能找到一级。