当我们做一些网站项目的时候,都会遇到这样一类问题,删除一个栏目,而这个栏目又不是最底层栏目,也就是说,被删除的栏目拥有子栏目,这时,我们执行删除该栏目的命令,就需要将该栏目及其子栏目一并删除,因为我们不可能让一个类的上级栏目被删除后,子栏目还显示或存在数据库中,这时候,栏目删除的问题就来了。

先上图:

  这是一个简单的权限管理的页面,图中管理员权限为顶级权限,栏目管理为管理员权限的子权限,栏目添加又为栏目管理的子权限,这样一个三级分类,我们想要达到的效果为:删除管理员权限,其下栏目管理、栏目添加权限全被同时删除;删除栏目管理权限,则栏目添加也同时被删除;删除栏目添加权限则只删除其本身。

接下来实现方法:

1.是控制器中简单删除方法:

     public function privilege_del(){
$pri = D('privilege');
$id = I('id');
if($pri->delete($id)){
$this->success('删除权限成功!',U('Privilege/privilege_lst'));
}else{
$this->error('删除权限失败!');
}
}

2.我们思考,我们想要的同时删除的结果,其实是当我们选择上级栏目删除时,代码首先帮我们删除该栏目类别的最底层的子栏目,然后依次向上删除,最终删除我们选择的上级栏目,所以我们需要写一个前置的构造函数进行操作 _before_delete($options) 这是ThinkPHP提供给我们的函数,他的用法是在我们执行删除方法前,执行这个函数,其中$options为我们要删除的信息,具体为一个二维数组,当我们把$options dump出来时,结果为:                                                                                                                                                                                                                                                                                     

  也就是说,如果我们想要取到这条信息的id值,只需要获取$options['where']['id']即可,但是注意,如果数组中的where同样是一个数组的时候,这就意味着我们进行的是批量删除,这也是单个删除和批量删除的区别所在,关于批量删除,之后我会再写一篇来简单介绍,这次我们只写单个删除。

  首先,写一个获取所有数据的方法childid,这里的$priid就是我们传进去的所要删除的那一栏的id

 public function childid($priid){
$data = $this->select();
return $this->getchildid($data,$priid);
}

  然后根据所有数据查找我们要删除的栏目的下面的子栏目的id,再次创建一个方法 getchildid获取所有需要删除的id

 public function getchildid($data,$parentid){
static $ret=array();
foreach ($data as $k => $v) {
if($v['parentid']==$parentid){
$ret[]=$v['id'];
$this->getchildid($data,$v['id']);
}
}
return $ret;
}

这里又用到了递归,在所有数据中查询完下级栏目后,查询下级栏目的下级栏目,最后将该栏目的所有子栏目的id版存到ret数组中,返回。

最后在构造函数中调用

      public function _before_delete($options){
//单个删除
$chilrenids =$this->childid($options['where']['id']);
$chilrenids = implode(',', $chilrenids);
if($chilrenids){
$this->execute("delete from ed_privilege where id in($chilrenids)");
}
}

将获取的id号用逗号隔开,因为此时不能再使用delete方法去删除数据,若使用则将再次调用构造函数成为死循环,所以我们需要在这里执行SQL语句进行数据删除。

以上就是单个栏目删除的全部内容。

ThinkPHP删除栏目(单)的更多相关文章

  1. ThinkPHP删除栏目(多)

    前段时间发表了一个删除栏目的随笔,当时实现的功能是删除一条信息,这次来实现一下批量删除栏目. 我们需要达到的是这样一个效果: 选中批量删除按钮后可以选中所有该页面的栏目,这个是前端页面的实现,在这里就 ...

  2. ThinkPHP递归删除栏目

    ThinkPHP递归删除栏目 https://www.cnblogs.com/zlnevsto/p/7051875.html Thinkphp3.2 无限级分类删除,单个删除,批量删除 https:/ ...

  3. MVC4做网站后台:栏目管理3、删除栏目与左侧列表菜单

    一.左侧列表菜单 打开视图Menu.cshtml,增加部分见红框 在category中添加脚本 //栏目菜单加载完毕函数 function CategoryMenu_Ready() { $('#cat ...

  4. SpringBoot日记——删除表单-Delete篇

    增删改查,我们这篇文章来介绍一下如何进行删除表单的操作,也就是我们页面中的删除按钮的功能. 下边写的可能看起来有点乱,请仔细的一步一步完成. 删除功能第一步,按钮功能实现 1. html的改变 来看, ...

  5. pageadmin CMS网站制作教程:栏目单页内容如何修改

    pageadmin CMS网站制作教程:栏目单页内容如何修改 一般情况下,如公司介绍,联系方式等介绍内页面都属于单页,单页内容可以直接在栏目设置界面进行修改,如下 1.对栏目单页内容进行设置,登录后台 ...

  6. 开源作品-ThinkPHP在线分析工具(单文件绿色版)-TPLogAnalysis_PHP_1_0

    TPLogAnalysis_PHP_1_0 前言:项目开发基于ThinkPHP框架,但是在调试程序的时候,没有一款日志可视化分析工具.在网络也找不到任何相关的TP日志分析工具.求人不如求己,于是决定抽 ...

  7. Java连接Jira,创建、修改、删除工单信息

    还不了解Jira是什么的同学可以看一下这篇文章:https://www.cnblogs.com/wgblog-code/p/11750767.html 本篇文章主要介绍如何使用Java操作Jira,包 ...

  8. ThinkPHP 删除数据

    ThinkPHP删除数据使用delete方法,例如: 直线电机价格 $Form = M('Form'); $Form->delete(5); 表示删除主键为5的数据,delete方法可以删除单个 ...

  9. Java——Java连接Jira,创建、修改、删除工单信息

    还不了解Jira是什么的同学可以看一下这篇文章:https://www.cnblogs.com/wgblog-code/p/11750767.html 本篇文章主要介绍如何使用Java操作Jira,包 ...

随机推荐

  1. [国嵌攻略][054][NandFlash驱动设计_写]

    Nand Flash支持按页写和随机写两种方式,在下面实现的是按页写.闪存在写数据时,只能写入1,不能写入0,所以写函数必须和擦除函数一起使用,并且擦除函数是按块擦除. /************** ...

  2. node中定时器, process.nextTick(), setImediate()的区别与联系

    1.定时器 setTimeout()和setInterval()与浏览器中的API是一致的,定时器的问题在于,他并非精确的(在容忍范围内).尽管事件循环十分快,但是如果某一次循环占用的时间较多,那么下 ...

  3. Linux命令之远程下载命令:wget

    转自:http://www.cnblogs.com/peida/archive/2013/03/18/2965369.html Linux系统中的wget是一个下载文件的工具,它用在命令行下.对于Li ...

  4. 我是如何将网站全站启用Https的?-记录博客安装配置SSL证书全过程

    评论»   文章目录 为什么要Https 如何选择Https 安装部署SSL证书 平滑过渡Https 搜索引擎的响应 启用Https小结 正如大家所看到的,部落全站已经启用了Https访问了,连续几天 ...

  5. php 下载文件的头信息 Determine Content Type

    <?php if(!function_exists('mime_content_type')) { function mime_content_type($filename) { $mime_t ...

  6. 实例说明optimize table在优化MySQL时很重要

    今天在看CU的时候,发现有人问有关optimize来表优化的问题,当年因为这个问题,困扰我很长一段时间,今天有空我把这个问题,用实际数据来展示出来,让大家可以亲眼来看看,optimize table的 ...

  7. spring-mvc整合jquery cropper图片裁剪插件

    参考网址:http://blog.csdn.net/u012759397/article/details/53126522

  8. wigs的理解和应用

    1. 首先了解下,Web应用的本质,大体如下: 1.浏览器发送一个HTTP请求: 2.服务器收到请求,生成一个HTML文档: 3.服务器把HTML文档作为HTTP响应的Body发送给浏览器: 4.浏览 ...

  9. u8g2库的相关资料

    2017-12-1309:13:32更新51论坛上的帖子,大神自己写的库文件,待调试! http://www.51hei.com/bbs/forum.php?mod=viewthread&ti ...

  10. linux_通配符

    通配符和正则表达式区别? 通配符用在用户命令行bash环境,而正则表达式用于linux三剑客(awk, sed, grep) 那,有哪些通配符? * 所有字符    五星 ls *.txt # 列举目 ...