0

0

删除一个栏目该如何做?

PHP中文网

PHP中文网

发布时间:2017-06-20 11:01:43

|

2248人浏览过

|

来源于php中文网

原创

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

先上图:

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

 

接下来实现方法:

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

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

 

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

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

拍拍客 免费易推广api系统
拍拍客 免费易推广api系统

这是一套由淘掌门(taozhangmen.net)衍生出来的一个拍拍客系统!这套程序也继承了淘掌门的特点:永久免费开源!无任何时间限制、功能限制、域名限制。 程序相对于淘掌门原型,已去除返利、会员系统、文章系统等。 如果需要文章,可单独下载其他的文章系统,做子目录,效果可能会更好。 程序安装过程与淘掌门相同: 下载上传到空间,执行 你的网址/install.php 安装完成后,登陆后台修改拍拍AP

下载

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

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

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

 1 public function getchildid($data,$parentid){ 2         static $ret=array(); 3         foreach ($data as $k => $v) { 4             if($v['parentid']==$parentid){ 5                 $ret[]=$v['id']; 6                 $this->getchildid($data,$v['id']); 7             } 8         } 9         return $ret;10     }

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

最后在构造函数中调用

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

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

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

 

相关专题

更多
微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

2

2026.01.18

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

74

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

133

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

54

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

19

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

106

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

44

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

11

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Rust 教程
Rust 教程

共28课时 | 4.5万人学习

Vue 教程
Vue 教程

共42课时 | 6.7万人学习

NumPy 教程
NumPy 教程

共44课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号