// 找一个分类所有子分类的ID
public function getChildren($catId)
{
// 取出所有的分类
$data = $this->select();
// 递归从所有的分类中挑出子分类的ID
return $this->_getChildren($data, $catId, TRUE);
}
/**
* 递归从数据中找子分类
*/
private function _getChildren($data, $catId, $isClear = FALSE)
{
static $_ret = array(); // 保存找到的子分类的ID
if($isClear)
$_ret = array();
// 循环所有的分类找子分类
foreach ($data as $k => $v)
{
if($v['parent_id'] == $catId)
{
$_ret[] = $v['id'];
// 再找这个$v的子分类
$this->_getChildren($data, $v['id']);
}
}
return $_ret;
}
// 获取树形数据
public function getTree()
{
$data = $this->select();
return $this->_getTree($data);
}
private function _getTree($data, $parent_id=0, $level=0)
{
static $_ret = array();
foreach ($data as $k => $v)
{
if($v['parent_id'] == $parent_id)
{
$v['level'] = $level; // 用来标记这个分类是第几级的
$_ret[] = $v;
// 找子分类
$this->_getTree($data, $v['id'], $level+1);
}
}
return $_ret;
}
protected function _before_delete(&$option)
{
/************** 修改原$option,把所有子分类的ID也加进来,这样TP会一起删除掉 *******/
// 先找出所有子分类的ID
$children = $this->getChildren($option['where']['id']);
$children[] = $option['where']['id'];
$option['where']['id'] = array(
0 => 'IN',
1 => implode(',', $children),
);
}
<form method="post" action="" name="listForm" onsubmit="">
<div class="list-div" id="listDiv">
<table cellpadding="3" cellspacing="1">
<tr>
<th>分类名称</th>
<th>操作</th>
</tr>
<?php foreach ($data as $k => $v): ?>
<tr class="tron">
<td><?php echo str_repeat('-', 8*$v['level']) . $v['cat_name']; ?></td>
<td align="center">
<a href="<?php echo U('edit?id='.$v['id']); ?>">修改</a>
<a onclick="return confirm('确定要删除吗?');" href="<?php echo U('delete?id='.$v['id']); ?>">删除</a>
</td>
</tr>
<?php endforeach; ?>
</table>
</div>
</form>