关于删除所有cate数据显示报错 解决方法 :
<!-- 在a标签定义cateid="{$cate.id}"来获取要修改的id 注意获取cateid的是json的不能直接调用 --> 使用这个注册不能放置到
{$cate.id}在注释的清空下也是被识别的 应该修改成{$//cate.id} 让系统不做识别即可
首先我们删除如果是菜单下面还依然有子菜单 根据pid值获取做判断 放到数组里面一同删除
这个对数据库进行操作的判断我们放置在model/Cate.php里面 代码:
//删除栏目递归判断该栏目下是否拥有子栏目返回数组一起删除
public function childrenids($cateid){
$data = $this->field('id,pid')->select();
return $this->_childrenids($data,$cateid);
}
private function _childrenids($data,$cateid){
static $arr = array();
foreach ($data as $k => $v){
//判断当前id的pid值等于cateid 就是cateid下面的子栏目
if ($v['pid']==$cateid) {
$arr[] =$v['id'];
//子栏目下面可能还有子栏目 就用递归方式实现
$this->_childrenids($data,$v['id']);
}
}
return $arr;
}
控制调用此方法app\Cate.php代码
//删除栏目
public function del(){
$cateid = Request::param('cateid');
$childrenids = model('cate')->childrenids($cateid);
$childrenids[] = $cateid;
//halt($childrenids);
$del = Db::table('tp_cate')->delete($childrenids);
if ($del){
$this->success('数据处理成功!','lst');
}else{
$this->error('数据处理成功!');
}
}