部门列表找每一个部门下的所有员工数,循环调用递归出现重复数组的问题
程序员文章站
2022-03-30 21:59:05
...
问题:
代码如下:
//查找所有下级部门的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;
}
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);
},
];
}
结果输出:
得出重复的数据,要是列表还有部门的话会这样一直重复下去,如何解决这个问题?
我需要的结果是每调用一次就能获取到当前部门下的所有子部门的id,以一维数组的形式展示。
把$GLOBALS['temp']=[];放开它只能找到一级。
回复内容:
问题:
代码如下:
//查找所有下级部门的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;
}
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);
},
];
}
结果输出:
得出重复的数据,要是列表还有部门的话会这样一直重复下去,如何解决这个问题?
我需要的结果是每调用一次就能获取到当前部门下的所有子部门的id,以一维数组的形式展示。
把$GLOBALS['temp']=[];放开它只能找到一级。
上一篇: win10右下角图标合并
下一篇: 股票软件的键盘精灵(php js)