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

先上图:

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

接下来实现方法:

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. 如何在SecureCRT中给linux上传和下载文件 安装redis

    首先建立文件 /download sz和rz命令无法用.则用以下1.和2.3步骤   需要上传或者下载,需要使用rz和sz命令.如果linux上没有这两个命令工具,则需要先安装.可以使用yum安装.运 ...

  2. HDU 5538 House Building(模拟——思维)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5538 Problem Description Have you ever played the vi ...

  3. HDU 1562 Oil Deposits

    题目: The GeoSurvComp geologic survey company is responsible for detecting underground oil deposits. G ...

  4. Java多线程编程—锁优化

    并发环境下进行编程时,需要使用锁机制来同步多线程间的操作,保证共享资源的互斥访问.加锁会带来性能上的损坏,似乎是众所周知的事情.然而,加锁本身不会带来多少的性能消耗,性能主要是在线程的获取锁的过程.如 ...

  5. 98、vue.js简单入门

    本篇导航: 介绍与安装 vue常用指令 一.介绍与安装 vue是一套构建用户界面的JAVASCRIPT框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue 的核心库只关注视图层, ...

  6. Use LiveCD to acquire images from a VM

    Forensic examiners usually acquire images from suspect's PC or Laptop. What if the target computer i ...

  7. Visual SVN Server启动失败0x8007042a错误

    载. 今天在程序VisualSVNServer界面中启动服务时,报错如下:       VisualSVNServerServer service failed to start:服务已返回特定的服务 ...

  8. 【开发技术】 使用JSP开发WEB应用系统-------笔记

    1.主机IP地址是:localhost     or    127.0.0.1    or     实际的IP地址 2.Tomcat 服务器是一个免费的开放源代码的Web 应用服务器 3.WebRoo ...

  9. RocketMQ-顺序消费

    看了https://www.jianshu.com/p/453c6e7ff81c这篇博客,得出顺序消费的结论."要实现严格的顺序消息,简单且可行的办法就是:保证生产者 - MQServer ...

  10. Java基础——反射 reflect

    什么是反射 (1)Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取的信息以及动态调用对象的方法的功能称 ...