PHP 循环删除无限分类子节点的实现代码

时间:2021-05-26

复制代码 代码如下:
<?php
private function _deleteSubNode($ids){

$subNodes = array();
$mod = D('Node');
foreach (explode ( ',', $ids ) as $k){
$res = $this->_getSubNode($k,$subNodes[$k],$mod); //获取子节点
if(!empty($res[0])){
foreach($res as $k => $nid){
$mod->where('id = '.$nid)->delete(); //删除子节点
}
}
}
return ;
}

private function _getSubNode($id, &$arr,$mod){

$condition = array ('pid' => array ('eq', $id ));
$ret = $mod->where($condition)->getField('id');
if(!empty($ret[0])){
foreach ($ret as $k => $node){
$arr[] = $node['id'];
$this->_getSubNode($node['id'], $arr, $mod);
}
}
return $arr;
}

?>

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章